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 12:00 | IT novinky

    Co způsobilo včerejší nejhorší výpadek Cloudflare od roku 2019? Nebyl to kybernetický útok. Vše začalo změnou oprávnění v jednom z databázových systémů a pokračovalo vygenerováním problém způsobujícího konfiguračního souboru a jeho distribucí na všechny počítače Cloudflare. Podrobně v příspěvku na blogu Cloudflare.

    Ladislav Hagara | Komentářů: 4
    včera 23:44 | Nová verze

    Byla vydána (Mastodon, 𝕏) první RC verze GIMPu 3.2. Přehled novinek v oznámení o vydání. Podrobně v souboru NEWS na GitLabu.

    Ladislav Hagara | Komentářů: 1
    včera 23:22 | Komunita

    Eugen Rochko, zakladatel Mastodonu, tj. sociální sítě, která není na prodej, oznámil, že po téměř 10 letech odstupuje z pozice CEO a převádí vlastnictví ochranné známky a dalších aktiv na neziskovou organizaci Mastodon.

    Ladislav Hagara | Komentářů: 0
    včera 19:44 | Nová verze

    Byla vydána nová major verze 5.0 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v obsáhlých poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 14:00 | Upozornění

    Cloudflare, tj. společnost poskytující "cloudové služby, které zajišťují bezpečnost, výkon a spolehlivost internetových aplikací", má výpadek.

    Ladislav Hagara | Komentářů: 10
    včera 04:22 | Pozvánky

    Letos se uskuteční již 11. ročník soutěže v programování Kasiopea. Tato soutěž, (primárně) pro středoškoláky, nabízí skvělou příležitost procvičit logické myšlení a dozvědět se něco nového ze světa algoritmů – a to nejen pro zkušené programátory, ale i pro úplné začátečníky. Domácí kolo proběhne online od 22. 11. do 7. 12. 2025 a skládá se z 9 zajímavých úloh různé obtížnosti. Na výběru programovacího jazyka přitom nezáleží – úlohy jsou

    … více »
    SoutezKasiopea | Komentářů: 1
    včera 04:11 | Nová verze

    Byla vydána nová verze 2.52.0 distribuovaného systému správy verzí Git. Přispělo 94 vývojářů, z toho 33 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    17.11. 18:00 | Nová verze

    VKD3D-Proton byl vydán ve verzi 3.0. Jedná se fork knihovny vkd3d z projektu Wine pro Proton. Knihovna slouží pro překlad volání Direct3D 12 na Vulkan. V přehledu novinek je vypíchnuta podpora AMD FSR 4 (AMD FidelityFX Super Resolution 4).

    Ladislav Hagara | Komentářů: 0
    17.11. 03:11 | Nová verze

    Poštovní klient Thunderbird byl vydán v nové verzi 145.0. Podporuje DNS přes HTTPS nebo Microsoft Exchange skrze Exchange Web Services. Ukončena byla podpora 32bitového Thunderbirdu pro Linux.

    Ladislav Hagara | Komentářů: 2
    17.11. 02:33 | IT novinky

    U příležitosti státního svátku 17. listopadu probíhá na Steamu i GOG.com již šestý ročník Czech & Slovak Games Week aneb týdenní oslava a také slevová akce českých a slovenských počítačových her.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (19%)
     (18%)
     (23%)
     (15%)
     (23%)
     (15%)
     (17%)
    Celkem 369 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    Rozcestník

    Programování: záhadné chyby

    3.3.2007 14:05 | Přečteno: 1622× | Programování | poslední úprava: 10.3.2009 13:32

    Zrovna nedávno mě potrápila jedna "záhadná" chybička. Tak se s vámi o ni podělím...

    Již celkem pozdě v noci, unavený jsem chtěl rychle přidat další funkce do jednoduchého miniprográmku, aby jsem ho mohl ihned použít a ulehčit si práci. Vždy otevře soubor, zjistí jestli je v něm to co chci a případně to vypíše na obrazovku. Má dva režimy používání. V tom prvním pracuje pouze s jedním souborem a v tom druhém projede rekurzivně všechny soubory v zadaném adresáři.

    Nové funkce nechtěly stále fungovat, nu co tak přidám ladící printf část, abych odhalil kde je chyba. No jo, ale po kompilaci se mi nic na obrazovku nevytisklo. Říkam si, že je to nějaké divné, na ten řádek se to přeci musí tak jako tak dostat. A v tu chvíli jsem udělal zásadní chybu. Já byl býk, těch pár řádků pohybující se červená muleta (BTW: Býk je barvoslepý, dráždí ho pohyb mulety a bolest, kterou mu toreador způsobuje, ne barva. Taky jsem se totiž stal obětí tohoto mýtu :-D) a zbytek kódu byl toreador.

    Nu což upravil jsem i přímo řádky, které provádějí výpis informací ze souboru, ale spuštěný program opět vypsal to samé jako prve. To přeci není možné. V programu není nikde jinde místo, kde by se tyto informace tiskly. Pustím program s parametrem --version a kontroluju čas kompilace, ten sedí, opravdu spouštím nově zkompilovanou binárku. V tuto chvíli chybuji znovu, začínám věřit na abnormální jevy místo, abych použil logiku a zjistil příčinu. Hlavou se mi honí podivné myšlenky. Zakomentuju printf a program mi stále tiskne informace. Jak je to možné?

    Dám jeden velký printf("**********************************\n"); hned na začátek programu. Celou dobu jsem volal program s volbou pro rekurzivní zpracování více souborů v adresáři a teď se divil, že se mi hvězdičky vytiskly pouze při zpracování prvního souboru. Ha, konečně mi to došlo.

    První verze programu uměla zpracovávat pouze jeden soubor a teprve po odladění jsem dodal podporu pro více souborů najdenou. A proč vymýšlet již hotové věci, že? Jako nejrychlejší řešení mi přišlo toto:

      if (user_arg.dirname[0] != 0) {
        char command[COMMAND_MAX];
    
        memset(command, 0, COMMAND_MAX);
        snprintf(command, COMMAND_MAX, "find %s -type f -regex '.*fit' | xargs -i %s -f {} -k '%s' -v '%s' -c '%s'",
                 user_arg.dirname, APP_NAME, user_arg.keyword, user_arg.value, user_arg.compare);
        if (user_arg.ignore_case == 1)
          strcat(command, " -i");
        if (user_arg.print_filename == 1)
          strcat(command, " --print-filename");
    
        system(command);
        exit(EXIT_SUCCESS);
      }
    

    Po 's/APP_NAME/argv[0]/' najednou zmizely nadpřirozené jevy, vztek, všechno začalo krásně fungovat a já se rozesmál. V /usr/local/bin byla stará binárka, takže jsem sice opravdu spouštěl binárku novou, ale vzápětí "skrytě" volal tu starou ;-)

    Takže ponaučení zní: "Nikdy se přehnaně nesoustřeďte na jedno místo, ale vždy se na problém podívejte s dostatečným nadhledem a při jeho řešení berte v úvahu vše co s ním souvisí. Krok za krokem kontrolujte všechny články řetězce a dříve či později musíte narazit na ten vadný. Zachovejte chladnou hlavu."

    Snadno se radí, špatně se koná. Občas je člověk v takovém psychickém stavu, že udělá věci, které by jinak neudělal...

           

    Hodnocení: 57 %

            špatnédobré        

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

    Komentáře

    Vložit další komentář

    3.3.2007 14:46 Lu-Tze | skóre: 15 | blog: Lu-Tzeho blog
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Nelíbí se mi to :-) Zdá se mi, že by bylo lepší, aby tvůj program akceptoval na vstupu libovolné množství souborů a v případě rekurzivního použití by se volal skriptíkem, kde by byl ten find atd. Tohle je fuj.
    3.3.2007 15:43 tommy
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    ja poznam jeden velmi zakerny kod v jave

    ResultSet xy

    ..

    ..

    while (xy.next());

    {

    xy.get(....

    }

    niekolko hodin som stravil premyslanim preco mi to vracia 1 zanam ked ich tam je 9 tisic....
    Bluebear avatar 3.3.2007 20:12 Bluebear | skóre: 30 | blog: Bluebearův samožerblog | Praha
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Jo, na tohle už jsem si taky párkrát naběhl :-)

    Myslím, že na syntaktické anomálie, jako je tahle, by měl být v kompilátoru warning. Osobně bych dokonce byl pro to, aby ty složené závorky za podmínkou v příkazu "if" byly povinné.
    To mi připomíná, jak jsem si pořídil květináč, že v něm budu mít květinu. Opravdu tam byla, ale potom být přestala...
    xxx avatar 3.3.2007 20:30 xxx | skóre: 42 | blog: Na Kafíčko
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Ha, konecne jsem pochopil o co slo :-)
    Please rise for the Futurama theme song.
    3.3.2007 21:27 jk
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Me Eclise tuhle konstrukci oznaci warningem - Emty flow statement.
    4.3.2007 01:35 tommy
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Tiez pouzivam Eclipse, a vsimol som si az vted ked som tam kvoli testovaniu

    zmenil na while (true);, a zrazu mi napisalo ze code unrechable....

    Ja osobne by som bol aspon za nejaky kompiler warning, lebo hladanie

    takychto chyb ma pripravuje o psychicke zdravie

    4.3.2007 11:41 jk
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Code unreachable imho neni warning ale error. A napsal ti ho proto, ze tam mas nekonecnej cyklus, kterej neobsahuje return, break, nebo neco podobnyho, s tim strednikem nesouvisi.

    Jinak ten empty flow statement warning mozna neni standartne zapnutej. Ja jsem si v Eclipse zapnul skoro vsechny mozny warningy, takze mozna byl mezi nima.
    5.3.2007 08:28 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Osobně bych dokonce byl pro to, aby ty složené závorky za podmínkou v příkazu "if" byly povinné.
    V tom prípade, perl je jazyk pre vás :-D
    Inak, celý tento problém s bodkočiarkou je len nafúknutá bublina. Stačí mať otváraciu { na riadku s while/if/...
    a potom už v len Makefile spočítať riadky, kde s m/;\s*{/ :-))
    Josef Kufner avatar 3.3.2007 16:13 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Programování: záhadné chyby
    Hádej co mám v patičce ;-)

    Btw, neinicializovaný pointer dokáže ještě lepší věci. Jednou mi program v GTK chcípnul, když jsem při inicializaci socketu předal jedné funkci neinicializovaný pointer. Všechno se zdálo být funkční, povídalo si to, nespadlo to, okno se překreslovalo, ale jakmile jsem z jednoho GtkHBoxu odstranil poslední widget, tak si to se mnou přestalo povídat. Okno se i nadále překreslovalo, ale prostě to nic nedělalo... Od té doby inicializuju úplně všecky pointery i když vím, že je to zbytečné. Pak to totiž spadne hned :-D
    Hello world ! Segmentation fault (core dumped)

    Založit nové vláknoNahoru

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