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í
×
15.6. 22:44 | Zajímavý článek

Na blogu projektu NeoPG (GitHub), kryptografického softwaru vycházejícího z GnuPG, byly zveřejněny 4 příspěvky detailně popisující aktuální bezpečnostní problémy v GnuPG a souvisejících softwarových produktech. V prvním příspěvku je ukázáno, že je možné vytvořit zprávu, o které budou Earlybird, Evolution, Mutt nebo Outlook tvrdit, že jí dešifrovali a přitom ale zpráva vůbec zašifrována nebyla. V druhém příspěvku je popsána

… více »
Ladislav Hagara | Komentářů: 5
15.6. 13:00 | Komunita

GamingOnLinux informuje, že počítačová hra Track Mania Nations Forever (Steam, Wikipedie) pro Windows je nově dostupná také jako snap. Stejně jako v případě winepaku a Flatpaku se k běhu hry používá překladová vrstva Wine.

Ladislav Hagara | Komentářů: 12
14.6. 15:12 | Komunita

Tradiční setkání příznivců operačního systému Linux pod názvem Linux párty Teplice se bude konat v pátek 15. 6. 2018 v Hospůdce u černé Kočky od 18:00 hodin. Setkají se zde pamětníci příkazové řádky, vítáni jsou však i začínající uživatelé.

František Bublík | Komentářů: 21
14.6. 14:00 | Bezpečnostní upozornění

Intel potvrdil (INTEL-SA-00145) další bezpečnostní chybu ve svých procesorech. Jedná se o chybu CVE-2018-3665 s názvem LazyFP.

Ladislav Hagara | Komentářů: 12
14.6. 11:00 | Nová verze

Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 153. brněnský sraz, který proběhne v pátek 15. června od 18:00 v restauraci U OSLŮ na ulici Sokolská 361/10. Pro zájemce proběhne krátké promítání z výletu do Černobylu.

Ladislav Hagara | Komentářů: 0
13.6. 19:58 | Upozornění

Server lupa.cz rozebírá připravovanou reformu copyrightu v EU a dopad jejího článku 13, který dává internetovým platformám povinnost řešit autorské právo za vlastníky práv, což by v podstatě vedlo k automatizované cenzuře a konci internetu tak, jak ho známe dnes. Podobně v otevřeném dopise varují Vint Cerf, Tim Berners-Lee a jiní odborníci, Cory Doctorow upozorňuje na důsledky pro Wikipedii, nebo github na sdílení kódu.

marbu | Komentářů: 95
12.6. 16:00 | Nová verze

Bylo oznámeno vydání verze 5.13 prostředí KDE Plasma. Přehled nových vlastností i s náhledy v poznámkách k vydání. Videoukázka na YouTube.

Ladislav Hagara | Komentářů: 94
12.6. 11:11 | Zajímavý software

Byla vydána verze 1.8.0 svobodného softwaru Dilay pro 3D modelování technikou digitálního sochání (digital sculpting). Zdrojové kódy jsou k dispozici na GitHubu pod licencí GPLv3. K dispozici je balíček (19,6 MB) ve formátu AppImage. Stačí nastavit právo na spouštění a spustit.

Ladislav Hagara | Komentářů: 10
11.6. 16:55 | Zajímavý projekt

MojeFedora.cz představuje repozitář Flatpaku winepak, který si dává za cíl přinášet do Linuxu aplikace pro Windows v podobě Flatpaku. K běhu aplikací se používá překladová vrstva Wine.

Ladislav Hagara | Komentářů: 28
11.6. 16:33 | Komunita

V rámci letních slev na GOG.com lze do středy 13. června do 15:00 získat počítačovou hru Ziggurat (Wikipedie) běžící také na Linuxu zdarma a bez DRM.

Ladislav Hagara | Komentářů: 0
Jak čtete delší texty z webových stránek?
 (78%)
 (23%)
 (4%)
 (7%)
 (3%)
 (11%)
Celkem 198 hlasů
 Komentářů: 35, poslední dnes 12:19
    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: 531×
    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: 68
    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.