abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 17
    včera 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    19.12. 17:00 | Komunita

    Nový CEO Mozilla Corporation Anthony Enzor-DeMeo tento týden prohlásil, že by se Firefox měl vyvinout v moderní AI prohlížeč. Po bouřlivých diskusích na redditu ujistil, že v nastavení Firefoxu bude existovat volba pro zakázání všech AI funkcí.

    Ladislav Hagara | Komentářů: 1
    Kdo vám letos nadělí dárek?
     (33%)
     (2%)
     (10%)
     (2%)
     (1%)
     (2%)
     (16%)
     (19%)
     (14%)
    Celkem 83 hlasů
     Komentářů: 18, poslední včera 15:30
    Rozcestník

    Dotaz: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?

    22.5.2012 19:22 NitroN2O
    PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Přečteno: 614×
    Mam triedu Trieda:
    class Trieda
    {
    	private $premenna;
    	private $kolekcia;
    	
    	function __construct() { $this->kolekcia = new Kolekcia; }
    	
    	function getPremenna() ...
    	function getKolekcia() ...
    	
    	function __get($name)
    	{
    		switch ($name)
    		{
    			case "premenna": return $this->getPremenna();
    			case "kolekcia": return $this->getKolekcia();
    			default: throw new MemberAccessException($name);
    		}
    	}
    }
    ktora obsahuje kolekciu kolekcia:
    class Kolekcia
    {
    	function add(Polozka $item) ...
    	function remove(Polozka $item) ...
    }
    do ktorej sa pridavaju polozky v kazdej polozke by som chcel mat moznost pristupovat k premennej tiredy "Trieda":
    class Polozka
    {
    	function metoda()
    	{
    		echo ...->premenna;
    	}
    }
    Viete mi poradit co najkratsi sposob ako to urobit? Zatial to riesim cez DI, cez konstruktor vkladam vzdy korenovu triedu. To je sice pekne, ale ked bude ta trieda zanorena dajme tomu 10 urovni, tak musim upravovat vsetky "medzi" triedy. Existuje nejaky "krajsi" sposob ako DI?

    Odpovědi

    Josef Kufner avatar 22.5.2012 23:04 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    A čeho vlastně chceš docílit?
    Hello world ! Segmentation fault (core dumped)
    Saljack avatar 22.5.2012 23:12 Saljack | skóre: 28 | blog: Saljack | Praha
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Navíc co znamená
    PHP, Python, C++, ..
    v javě existuje super, což je právě předek třídy. Spíš by se hodilo přiložit jednoduchý UML diagram, který by znázornil o co se snažíš.
    Sex, Drugs & Rock´n Roll.
    22.5.2012 23:37 NitroN2O
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Nejde o dedicnost, ale o vnaranie objektov.

    Predstavte si nieco podobne ako DOM strom. Objekt obsahuje kolekciu vnorenych objektov a ja chcem pristupovat z vnoreneho objektu(v tej kolekcii) k rodicovskemu objektu(nie v zmysle dedicnosti, ale v ramci hierarchie vnorenych objektov). Poznam jedno riesenie pomocou DI, lenze to je ukecane, a pri kazdej malej zmene musim upravovat hned niekolko tried.

    Ide mi len o design pattern. PHP, Python, C++, .. znamena ze mi to mozete vysvetlit v hociktorom z tychto jazykov.

    Vopred diky.
    Saljack avatar 23.5.2012 00:28 Saljack | skóre: 28 | blog: Saljack | Praha
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Aha tak to jsem tě blbě pochopil. Nejprve bych se zaměřil na návrh protože jestliže musíš kvůli jedné věci upravovat několik tříd něco je blbě. Já bych to řešil tak, že každý objekt musí dědit od jednoho objektu, který v sobě bude nést ukazatel na předka. A toho předka bych pak nastavoval v právě v metodě add popřípadě odebíral v remove. Jestli to teda správně chápu?
    Sex, Drugs & Rock´n Roll.
    23.5.2012 08:37 DK
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    pripadne jeste,co me tak napada, vytvor u vnorenych trid konstruktor s odkazem na vytvorenou tridu (tj pak budes kolekci vytvaret jako $this->kolekce=new Kolekce($this);, kdovi, jestli to bude fungovat, muzes to pekne zacyklit, ale za zkousku nic nedas :)
    rADOn avatar 23.5.2012 17:00 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Ide mi len o design pattern. PHP, Python, C++, .. znamena ze mi to mozete vysvetlit v hociktorom z tychto jazykov.
    Když ti to vysvětlím v pajtnu tak to v C++ zaručeně nenaprogramuješ :-)
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    rADOn avatar 28.5.2012 13:24 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Jak to tak po sobě čtu tak zní dost plamenně což jsem nechtěl. Vysvětlím – python má (nepříliš známou) vlastnost jménem deskriptory která umožňuje zachytit instanci zevnitř atributu. Takže ukázkový kód v pythonu by toho moc neukázal, jenom nějakou magii uvnitř interpretru.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    23.5.2012 09:38 Mr.S1lent.cz
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Vzdyt to mas standartni Category -> item model.

    Kategorii vytvoris properties:

    < Category> parent < array: Category> children < array: Item> items

    a pro rychle prochazeni stromem napric nekolika urovnim i pole klicu v kategorii s referencemi, treba:

    < array: (Category + Item)> referencesList

    klice si pak muzes generovat z nazvu kategorii (a subkategorii ) + nazvu daneho itemu, anebo treba mit static id v category + item a incrementovat/decrementovat je pri kazde zmene a navzajem synchronizovat...

    23.5.2012 23:49 l0gik | skóre: 22
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Úplně tomu nerozumím, zdá se mi, že poněkud mícháš vnořování tříd a dědičnost.

    Obecně, pokud k něčemu přistupuješ, tak bys to tam měl nějak přes DI vložit. Myslím, že žádné jiné řešení prostě nefunguje.

    Akorát můžeš zvážit, zdali má smysl, by Kolekce věděla o třídě (pak to bude posloupnost DI, tzn Položka bude mít metodu getKolekce a kolekce getTrida) nebo ne, v druhém případě pak Kolekci skryješ a vystavíš vlastnosti add a remove přímo v třídě, kde zároveň se správně aktualizuje DI pro vkládanou a odebíranou položku.

    DI je holt ukecaný, ale zpravidla je to i tak ten nejlepší způsob.
    28.5.2012 15:29 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: PHP, Python, C++, .. - ako pristupovat ku korenovej triede?
    Kořenová třída není moc šťastný název. Je to spíš nějaký globální stav aplikace, aplikační kontext. Používá se k tomu buď globální proměnná nebo singleton. Obojí jsou návrhové antivzory, tj. jejich použití často svědčí o špatném návrhu. Propagovat to skrze 10 tříd je sice způsob, jak globální objekt nebo singleton zrušit, ale taky to není šťastné řešení. Pátral bych po tom, k čemu vlastně ten kontext v desáté vnořené třídě potřebujete, a zda se to nedá nahradit něčím, co nebude vytvářet takhle dlouhé vazby napříč aplikací a bude lépe odpovídat objektovým principům, že každý objekt má vymezené kompetence. Samozřejmě se může ukázat, že napsat to správně by bylo příliš složité a globální kontext je sice ošklivý, ale napíše se rychle. Problém pak bude s údržbou.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.