Byl vydán Mozilla Firefox 127.0. Přehled novinek v poznámkách k vydání, poznámkách k vydání pro firmy a na stránce věnované vývojářům. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 127 je již k dispozici také na Flathubu a Snapcraftu.
Byla vydána (𝕏) nová verze 9.5 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání.
Společnost Raspberry Pi dnes vstoupila na Londýnskou burzu jako Raspberry Pi Holdings plc (investor).
Do 17. června do 19:00 běží na Steamu přehlídka nadcházejících her Festival Steam Next | červen 2024 doplněná demoverzemi, přenosy a dalšími aktivitami. Demoverze lze hrát zdarma.
Apple na své vývojářské konferenci WWDC24 (Worldwide Developers Conference, keynote) představil řadu novinek: svou umělou inteligenci pojmenovanou jednoduše Apple Intelligence, iOS 18, visionOS 2, macOS Sequoia, iPadOS 18, watchOS 11, …
Vyšla nová verze XMPP (Jabber) klienta Gajim, která přidává podporu reakcí pomocí emoji (XEP-0444: Message Reactions) a citace zpráv (XEP-0461: Message Replies). Přehled dalších vylepšení je k dispozici na oficiálních stránkách.
Po po téměř roce vývoje od vydání verze 5.38 byla vydána nová stabilní verze 5.40 programovacího jazyka Perl (Wikipedie). Do vývoje se zapojilo 75 vývojářů. Změněno bylo přibližně 160 tisíc řádků v 1 500 souborech. Přehled novinek a změn v podrobném seznamu.
Uroš Popović popisuje, jak si nastavit Linux na desce jako Raspberry Pi Zero, aby je šlo používat jako USB „flešku“.
Andreas Kling oznámil, že jelikož už se nevěnuje nezávislému operačnímu systému SerenityOS, ale výhradně jeho webovému prohlížeči Ladybird, přičemž vyvíjí primárně na Linuxu, SerenityOS opustí a Ladybird bude nově samostatný projekt (nový web, repozitář na GitHubu).
Po dvou měsících vývoje byla vydána nová verze 0.13.0 programovacího jazyka Zig (GitHub, Wikipedie). Přispělo 73 vývojářů. Přehled novinek v poznámkách k vydání.
Asi každému něco řekne, když někdo o nějaké třídě prohlásí, že je to singleton. Ale možná ne každému (stejně jako do dneška mě) nic neřekne, pokud někdo o třídě řekne, že je borg.
Idea singletonu je, že v celém programu existuje maximálně jedna instance dané třídy. Nicméně tento požadavek může být často příliš tvrdý, jelikož ve skutečnosti často požadujeme, aby kterákoliv instance dané třídy měla stejný stav, což zařídíme tím, že dovolíme, aby existovala pouze jedna instance, která logicky bude mít všude stejný stav.
Existuje ale ještě jeden možný přístup, který je většinou logicky bližší našim požadavkům, a to, že je nám jedno, kolik instancí si kdo kde vytvoří, ale všechny tyto instance budou ve stejném stavu. A toto je borg
class Borg: __shared_state = {} def __init__(self): self.__dict__ = self.__shared_state borgA = Borg() borgB = Borg() borgA.pozdrav = "My jsme Borg, budete asimilovani" print borgB.pozdrav
Tiskni Sdílej:
Zrovna tahle Pythonní implementace mi připadá jako zakuklený Singleton, přičemž se na interpreter hodila starost, aby ten stav byl nanejvýš jeden.
Nemohl bys uvést příklad, kde se hodí Borg víc, než Singleton?
Singleton::getinstance()
používáš new Singleton()
. V singletonu by ti new
narazilo na absenci public konstruktoru. Jinak se to chová úplně stejně.
>>> borgA is borgB False >>> id(borgA), id(borgB) 33097776, 33695504Borgove jsou rozdilne instance na ruznych mistech v pameti, zatimco singleton je jedina instance. Napriklad muzu dva borgy pouzit jako dva ruzne klice slovniku (pomijim ted ze pouzivat inherentne promenlivy objekt jako klic je blbost). Muzu vymyslet vyfikundace s borgy kteri budou instance ruznych trid ale sdilet stejny stav. Et cetera, et cetera… Mozna by se dalo i vymyslet rozumny pouziti pro neco takoveho, ale to uz bude asi kapku tezsi btw borg v new-style tride vypada takhle:
class Borg(object): shared = {} def __new__(cls): self = object.__new__(cls) self.__dict__ = share return self seven, locutus = Borg(), Borg() seven is locutus # False
Mohl bys prosím tuto konstrukci pro nás nepythonisty vysvětlit?
Takže jde jen o to, že __shared_state je proměnná třídy?
A mohl bys prosím vysvětlit, co se děje v tom konstruktoru (?) __init__()?
A vůbec, kde se tam vzala proměnná "pozdrav"?
jednoduse receno, self.__dict__ je slovnik obsahujici vsechny atributy tridy. On ukazatel na ten slovnik atributu nastavil na ukazatel na tu tridni promennou -> vsechny instance maji stejnou sadu atributu.
Promenna pozdrav se tam vzala z
borgA.pozdrav = "My jsme Borg, budete asimilovani"
protoze python, pokud priradis do neexistujiciho atributu, ten atribut automaticky vytvori === prida do self.__dict__ novou dvojici klic-hodnota. A protoze self.__dict__ sdili (diky predchozimu 'hacku') vsichni borgove, muze ho borgB vypsat.
koukam ze sem to vysvetlil slozite jak mlaticku, ale to je tou nocni hodinou :)