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 05:00 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za duben (YouTube). Na Linuxu je vedle Qt frontendu nově k dispozici také GTK4 / libadwaita frontend.

    Ladislav Hagara | Komentářů: 2
    včera 20:22 | IT novinky

    Neziskové průmyslové konsorcium Khronos Group vydalo verzi 3.1 specifikace OpenCL (Open Computing Language). OpenCL je průmyslový standard pro paralelní programování heterogenních počítačových systémů.

    Ladislav Hagara | Komentářů: 0
    včera 13:11 | Nová verze

    Homebridge pro integraci chytrých domácích zařízení byl vydán ve verzi 2.0.0. Nově vedle protokolu HomeKit Accessory Protocol (HAP) podporuje standard chytré domácnosti Matter.

    Ladislav Hagara | Komentářů: 0
    včera 04:11 | Nová verze

    Omarchy je linuxová distribuce s dlaždicovým správcem oken Hyprland. Založena je na Arch Linuxu. Vydána byla v nové verzi 3.7.0 - The Gaming Edition. Z novinek lze vypíchnout příkaz omarchy a celou řadu herních možností.

    Ladislav Hagara | Komentářů: 2
    včera 03:11 | Nová verze

    CyberChef byl vydán v nové major verzi 11. Přehled novinek v Changelogu. CyberChef je webová aplikace pro analýzu dat a jejich kódování a dekódování, šifrování a dešifrování, kompresi a dekompresi, atd. Často je využívaná při kybernetických cvičeních a CTF (Capture the Flag).

    Ladislav Hagara | Komentářů: 0
    4.5. 20:11 | Nová verze

    Byla vydána nová verze 2.4.67 svobodného multiplatformního webového serveru Apache (httpd). Řešeno je mimo jiné 11 zranitelností.

    Ladislav Hagara | Komentářů: 0
    4.5. 14:44 | Zajímavý software

    Brush (Bo(u)rn(e) RUsty SHell) je v Rustu napsaný shell kompatibilní s Bash (Bourne Again SHell). Vydána byla verze 0.4.0.

    Ladislav Hagara | Komentářů: 3
    4.5. 04:44 | Komunita

    Google zveřejnil seznam 1 141 projektů (vývojářů) od 184 organizací přijatých do letošního, již dvaadvacátého, Google Summer of Code. Přihlášeno bylo celkově 23 371 projektů od 15 245 vývojářů ze 131 zemí.

    Ladislav Hagara | Komentářů: 4
    4.5. 03:00 | Komunita

    Na čem pracovali vývojáři GNOME a KDE Plasma minulý týden? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.

    Ladislav Hagara | Komentářů: 0
    3.5. 03:44 | Nová verze

    Open source počítačová hra na hrdiny NetHack (Wikipedie, GitHub) byla vydána v nové verzi 5.0.0. První verze této hry byla vydána v roce 1987.

    Ladislav Hagara | Komentářů: 5
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (9%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (24%)
    Celkem 1505 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník


    Vložit další komentář
    26.3.2005 10:11 Dataman
    Rozbalit Rozbalit vše Pomalé, paměť
    Nikdy nejde o to napsat co nejméně znaků. Důležitější je spíše optimalizace. Rekurzivní funkce ti zabere spoustu paměti. Schválně, jak ti bude u funkce strlen trvat, než sjede dvacet tisíc znaků a kolik ti zabere paměti. Ta moje ti paměti bude zabírat pořád stejně, ta tvoje ji bude neustále krást.
    int strlen(char *a){
      int i=0;
      while(*a)
      {
        ++i;
        ++a;
      }
      return i;
    }
    
    Luk avatar 26.3.2005 11:35 Luk | skóre: 47 | blog: Kacířské myšlenky | Kutná Hora
    Rozbalit Rozbalit vše Re: Pomalé, paměť
    Přesně tak. Rekurzivní funkce se hodí prakticky jen jako cvičení, jako ukázka, že to jde. Ale jsou vždycky pomalejší než totéž udělané iterací, navíc spotřebovávají paměť na zásobníku a ten navíc při "větším" počtu vnoření přeteče. Platí známé pravidlo, co jde udělat rekurzí, jde udělat iterací.
    Šifrování je absolutní nutnost a pomáhá chránit před nekalými živly
    27.3.2005 16:34 3018736794024648 | blog: plathel
    Rozbalit Rozbalit vše Re: Pomalé, paměť

    ech.. samozřejmě. úloha zněla ale "nejméně znaků", nikoli nejvýkonnější. Prostě toto není otázka z reálného světa, a nemá smysl se ptát jestli úloha "najděte nejkratší řešení" má smysl, stejně jako nemá smysl mnoho lidské činnosti.

    já vím že rekurze je v tomto případě úplná blbost. Nicméně musíš uznat, že pomocí rekurze je to řešení kratší než jiná, běžnější řešení.

    26.3.2005 11:15 Martin Čížek | skóre: 20 | Praha
    Rozbalit Rozbalit vše strcpy()
    char *strcpy(char *d, const char *s) 
    {
      char *ret = d;
      while ((*d++ = *c++))
        ;
      return ret;
    }
    

    P. S. K ,,sestřesení'' kódu do jedné řádky se uchylovat nebudu :-).

    P. P. S. Obě funkce se obvykle implementují v asembleru, ,,výkonný kód'' je na i386 tvořen pomocí jedné prefixované instrukce (+ nějaký ten vstup do funkce, cld a leave).

    Kdyby dva z nás byli dvěma z nich, všichni z nás by mohli být všemi z nich.
    26.3.2005 12:09 unchallenger | skóre: 69 | blog: unchallenger
    Rozbalit Rozbalit vše Re: strcpy()
    Ad P.P.S. Obvykle už ne. Obvykle je slušný kompilátor (gcc) implementuje přímo a dokáže optimalizovat in-line.
    26.3.2005 19:48 Martin Čížek | skóre: 20 | Praha
    Rozbalit Rozbalit vše Re: strcpy()
    Obecně souhlasím -- je pravda, že mikrooptimalizace se stále více nechávají na kompilátoru, ale existující implementace těchto základních knihovních funkcí na to obvykle nespoléhají. V glibc jsou tyto jednoduché funkce napsané v asembleru pro všechny možné architektury, plus je tam jedna generic implementace v čistém C.

    Jak tak na to koukám, v glibc jsou i ,,jemnější'' verze pro i486, i586 atd., které jsou implemetované v asembleru bez prefixových instrukcí (což je asi na procesorech s RISCovými rysy rychlejší).
    Kdyby dva z nás byli dvěma z nich, všichni z nás by mohli být všemi z nich.
    26.3.2005 20:04 Martin Čížek | skóre: 20 | Praha
    Rozbalit Rozbalit vše Re: strcpy()
    Špatně jsem si to přečetl tvůj příspěvek, máš samozřejmě pravdu. Ale to není v rozporu s tvrzením o implementaci knihovních funkcí strlen() a strcpy(), i když je pak třeba optimalizovaný kód nepoužívá :-).
    Kdyby dva z nás byli dvěma z nich, všichni z nás by mohli být všemi z nich.
    27.3.2005 16:44 3018736794024648 | blog: plathel
    Rozbalit Rozbalit vše Re: strcpy()
    ježda. samozřejmě. jenže tohle řešení má 35 platných znaků.. moje má 33 ;) proto jsem ho dával do blogu, protože je kratší než tahle klasika
    26.8.2010 22:08 Jan Turoň
    Rozbalit Rozbalit vše Re: Nejkratší implementace strlen a strcpy
    tahle je taky zajímavá :-)
    int strlen(char *str) {
      int i=0;
      for(;*(str+i);i++);
      return i;
    }
    

    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.