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 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 1
včera 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 4
včera 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
včera 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
včera 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
včera 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
včera 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
19.1. 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ářů: 9
19.1. 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
19.1. 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ářů: 35
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (73%)
 (3%)
 (11%)
Celkem 346 hlasů
 Komentářů: 25, poslední dnes 13:34
    Rozcestník
    Reklama

    Dotaz: Informace o optimalizacích pro PHP nebo debugger vnitřních procesů

    19.12.2011 20:17 ads
    Informace o optimalizacích pro PHP nebo debugger vnitřních procesů
    Přečteno: 232×
    Ahoj. Rád bych si optimalizovat program v PHP, ale potřeboval bych vědět, jak fungují vnitřní procesy a co si jazyk optimalizuje sám. Např. jestli fce count počítá vždy prvky v poli nebo jestli si někte pamatuje výsledek, kolik kroků a času zabere přiřazení reference na objekt místo jeho tahání třeba přes nějakou třídu Factory atd atd... Nevíte o nějakém zdroji, který popisuje detailně chování php 5 pro dané operace nebo lépe jak debugnout to co php zrovna dělá (myslím interně co dělá)? Teď akorát mohu porovnávat časy běhu programu, ale to je pro praktické optimalizace k ničemu.

    Odpovědi

    19.12.2011 21:17 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Informace o optimalizacích pro PHP nebo debugger vnitřních procesů
    Cokoliv uděláte vestavěnou funkcí je několika-násobně rychlejší než v PHP, cyklům, zvláště zahnízděným, se vyhýbat.
    Z logiky věci count() vždy vrátit do proměnné a a pak používat její hodnotu, a tvrdím si říct, že vždy spočítá prvky znovu (jednoduchým testem pomocí for dojdete ke stejnému závěru).
    Zdroj: Zdrojáky PHP.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    19.12.2011 21:26 ads
    Rozbalit Rozbalit vše Re: Informace o optimalizacích pro PHP nebo debugger vnitřních procesů
    Hrabat se ve zdrojácích phpčka je už trošku overkill. Céčko tak dobře neznám. Myslel jsem spíš něco jako strace, ale to mu neukáže všechno.
    20.12.2011 09:39 zulu
    Rozbalit Rozbalit vše Re: Informace o optimalizacích pro PHP nebo debugger vnitřních procesů
    a tvrdím si říct, že vždy spočítá prvky znovu
    Ne.
    jednoduchým testem pomocí for dojdete ke stejnému závěru
    Co?
    Zdrojáky PHP
    Ahá...
    AraxoN avatar 20.12.2011 10:23 AraxoN | skóre: 45 | blog: slon_v_porcelane | Košice
    Rozbalit Rozbalit vše Re: Informace o optimalizacích pro PHP nebo debugger vnitřních procesů
    Ne. Co? Ahá...
    To sme sa toho od Teba teda veľa dozvedeli...

    Na prvý pohľad by sa videlo logické, ak by si PHP udržiavalo prehľad o presnom počte prvkov v poli a pri volaní count() len toto číslo vrátilo. Bohužiaľ, z nejakého dôvodu PHP naozaj zakaždým keď sa volá count() fyzicky preráta počet prvkov v poli. (Overené v zdrojákoch PHP: /ext/standard/array.c)

    Takže je lepšie a rýchlejšie volať count() len raz, odložiť si ho do premennej a používať ho odtiaľ (ak daný cyklus nemení počet prvkov toho poľa). Jednoduchým testom by si naozaj došiel ku rovnakému záveru.
    A fine is a tax for doing wrong. A tax is a fine for doing well.
    20.12.2011 10:42 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Informace o optimalizacích pro PHP nebo debugger vnitřních procesů
    Stále si to tvrdím říct (a níže AraxoN to potvrdil i na základě zdrojáků), ale stačí jen něco jako:
    <?php
    ini_set("memory_limit","512M");
    
    function microtime_float()
    {
      list($usec, $sec) = explode(" ", microtime());
      return ((float)$usec + (float)$sec);
    }
    
    echo "Fill array\n";
    $start = microtime_float();
    $a = array();
    $max = 2000000;
    for($i=0;$i<$max;$i++)
      $a[] = $i;
    echo microtime_float() - $start,"\n\n";
    
    echo "Read for with i and count\n";
    $start = microtime_float();
    $r=0;
    for($i=0;$i<count($a);$i++)
      $r+=$a[$i];
    echo $r,"\n";
    echo microtime_float() - $start,"\n\n";
    
    echo "Read for with i\n";
    $start = microtime_float();
    $r=0;
    $cnt = count($a);
    for($i=0;$i<$cnt;$i++)
      $r+=$a[$i];
    echo $r,"\n";
    echo microtime_float() - $start,"\n\n";
    
    echo "Read foreach value only\n";
    $start = microtime_float();
    $r=0;
    foreach($a as $v)
      $r+=$v;
    echo $r,"\n";
    echo microtime_float() - $start,"\n\n";
    
    echo "Read foreach key → value\n";
    $start = microtime_float();
    $r=0;
    foreach($a as $k => $v)
      $r+=$v;
    echo $r,"\n";
    echo microtime_float() - $start,"\n\n";
    
    time php for.php u mě to dá výsledek
    Fill array
    0.790529966354
    
    Read for with i and count
    1999999000000
    0.672595024109
    
    Read for with i
    1999999000000
    0.30579996109
    
    Read foreach value only
    1999999000000
    0.329959869385
    
    Read foreach key → value
    1999999000000
    0.351605892181
    
    
    real	0m2.742s
    user	0m2.500s
    sys	0m0.224s
    
    Ad. zdrojáky, ty jsou obvykle nejlepší cesta jak porozumět tomu, jak to funguje, testem zjistíme jen chování v podmínkách testu a další nám možná uniknou…
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†

    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.