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í
×
dnes 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
dnes 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
dnes 00:08 | Pozvánky

V sobotu 18. 2. se v Praze v prostorách VŠE uskuteční od 9:30 již 4. ročník největší české konference o open source redakčním systému WordPress (WP) - WordCamp Praha 2017.

… více »
smíťa | Komentářů: 0
včera 23:58 | Komunita

Kryptoměnová komunita zahájila nový rok spuštěním projektu Blockchain.cz, jehož cílem je kolektivně nalézt ideální překlad pro čím dál frekventovanější slovo „blockchain“. Přispět návrhem může kdokoli. Sběr bude trvat až do konce září 2017. Následně bude probíhat dvoutýdenní veřejné hlasování, které bude zakončeno výběrem toho nejlepšího návrhu.

xHire | Komentářů: 3
včera 15:55 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno je celkově 270 bezpečnostních chyb. V Oracle Java SE je například opraveno 17 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 16 z nich. V Oracle MySQL je opraveno 27 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 5 z nich.

Ladislav Hagara | Komentářů: 0
včera 02:48 | Nová verze

Po půl roce od vydání verze 9.0 (zprávička) byla vydána verze 10.0 zvukového serveru PulseAudio. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 26
včera 00:33 | Komunita Ladislav Hagara | Komentářů: 8
18.1. 17:30 | Zajímavý článek

Mozilla.cz informuje, že webový prohlížeč Firefox bude od verze 53 obsahovat integrovaný prohlížeč dat ve formátu JSON. Firefox kromě strukturovaného prohlížení nabídne také možnost filtrace a uložení na disk. Dle plánu by měl Firefox 53 vyjít 18. 4. 2017.

Ladislav Hagara | Komentářů: 1
18.1. 11:00 | Komunita

Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už zítra 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.

xkucf03 | Komentářů: 1
17.1. 21:55 | Komunita

Nadace pro svobodný software (FSF) oznámila aktualizaci seznamu prioritních oblastí (changelog), na které by se měli vývojáři a příznivci svobodného softwaru zaměřit. Jsou to například svobodný operační systém pro chytré telefony, hlasová a video komunikace nebo softwarový inteligentní osobní asistent.

Ladislav Hagara | Komentářů: 20
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (11%)
Celkem 332 hlasů
 Komentářů: 24, poslední 17.1. 10:14
    Rozcestník
    Reklama

    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: 528×
    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: 66
    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: 66 | 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.