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 09:44 | Zajímavý software

Kalifornskému Muzeu počítačové historie (Computer History Museum) se po pěti letech vyjednávání se společností Qualcomm podařilo získat veškerá práva na poštovního klienta Eudora (Wikipedie), tj. kromě zdrojových kódů muzeum získalo také ochranní známku Eudora nebo domény eudora.com a eudora.org. Po pročištění byly zdrojové kódy Eudory uvolněny pod licencí BSD.

Ladislav Hagara | Komentářů: 0
včera 15:00 | Nová verze

Byla vydána nová stabilní verze 5.11 toolkitu Qt. Přehled novinek v příspěvku na blogu a na wiki stránce. Další dnešní příspěvek na blogu Qt je věnován Qt pro WebAssembly umožňujícímu běh Qt aplikací ve webovém prohlížeči. K vyzkoušení jsou příklady.

Ladislav Hagara | Komentářů: 0
včera 12:22 | Nová verze

Po 7 měsících vývoje od verze 0.12.0 byla vydána verze 0.13.0 hardwarově nenáročného desktopového prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklého sloučením projektů Razor-qt a LXDE. Přehled novinek v oznámení o vydání a v příspěvku ve fóru.

Ladislav Hagara | Komentářů: 9
včera 12:11 | Pozvánky

V úterý 29. května v 18:00 se v Brně koná pátý přednáškový večer o webovém vývoji. Čeká vás povídání o frameworku v Elixiru, vydávání nové kryptoměny přes ICO, component trees v Reactu. Na místě bude lehké občerstvení; vstup zdarma pro registrované. Více informací na Facebooku nebo se rovnou registrujte na Meetup.

dejvik | Komentářů: 0
včera 12:00 | Pozvánky

V pátek 25. května 2018 v Praze proběhne společné setkání komunity kolem Drupalu a překladatelů softwaru – tématem bude právě lokalizace svobodného softwaru (nejen Drupalu). Program začíná v 9.30 v budově Českého rozhlasu (Vinohradská 12), ale můžete přijít i později během dne.

Fluttershy, yay! | Komentářů: 0
včera 06:55 | Zajímavý software

Operační systém 9front, zřejmě nejaktivněji vyvíjený neoficiální fork systému Plan 9 (více informací), se dočkal nové verze nazvané „Ghost in the Minesweeper Shell“. K novým vydáním obvykle dochází každé jeden až tři měsíce.

Fluttershy, yay! | Komentářů: 0
včera 02:00 | Bezpečnostní upozornění

Byly zveřejněny (Project Zero, Intel, AMD, Arm) informace o dalších 2 bezpečnostních chybách v procesorech: variantě 3a aneb CVE-2018-3640 - Rogue System Register Read (RSRE) a variantě 4 aneb CVE-2018-3639 - Speculative Store Bypass (SSB). Podrobnosti o chybě CVE-2018-3639 například v příspěvku na blogu Red Hatu. Princip vysvětlen pomocí videa na YouTube.

Ladislav Hagara | Komentářů: 3
21.5. 19:44 | Zajímavý software

Spolek vpsFree.cz na svém blogu informuje, že přechází z OpenVZ na vpsAdminOS. Distribuce vpsAdminOS je založena na NixOS a not-os. Pokud provozujete OpenVZ Legacy a nevíte co dál, můžete zvážit vpsAdminOS, který je na migraci kontejnerů z OpenVZ připraven.

Ladislav Hagara | Komentářů: 4
21.5. 10:22 | Komunita

Minulý týden byla ze správce souborů (Files, Soubory, Nautilus) v GNOME odstraněna možnost spouštění aplikací. Po bouřlivé diskusi byla dnes tato možnost do správce souborů vrácena (commit).

Ladislav Hagara | Komentářů: 29
20.5. 22:44 | Nová verze

Ani ne po měsíci vývoje od vydání verze 2.10.0 byla vydána nová verze 2.10.2 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP. Přehled novinek i s náhledy v oznámení o vydání. Opraveno bylo 44 chyb. Novinkou je podpora formátu HEIF (High Efficiency Image File Format) a dva nové filtry.

Ladislav Hagara | Komentářů: 63
Používáte pro některé služby inetd?
 (35%)
 (23%)
 (42%)
Celkem 144 hlasů
 Komentářů: 5, poslední včera 16:46
    Rozcestník

    Dotaz: C ukazatel přetečení zásobníku

    4.1.2014 23:05 kammtar
    C ukazatel přetečení zásobníku
    Přečteno: 538×
    Zdravím, Narazil jsme na jednu věc a docela by mě zajímalo proč.

    char *buff; getcwd(buff,100);

    Vyzkoušel jsem tento kód funguje správně ale v momentě kdy se snažím do programu přidat byť i jenom jeden int tak to skončí na SIGSEV.

    Vím že za použití malloc je problém vyřešen ale mě zajímá proč. Aji když si getcwd alokuje něco kolem 100*sizeof(char) tak to nemůže zaplnit celý zásobník ne? Dále v programu už používám jenom opendir() který mi snad nehází ty data na zásobník.

    Odpovědi

    4.1.2014 23:18 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    char *buff je jen neinicializovaný (ukazující kdokoliv ví kam), nealokuje žádnou paměť.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    4.1.2014 23:19 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    Oprava:
    char *buff je jen neinicializovaný ukazatel/pointer (ukazující kdokoliv ví kam), nealokuješ žádnou paměť.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    4.1.2014 23:25 kammtar
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    To je mi jasné, ale proč to pokaždé funguje? Podle manuálu getcwd() si alokuje paměť když je pointer na buffer null což není.
    4.1.2014 23:29 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    C-čko tě nekontroluje co děláš, nikdo nic nealokuje, prostě to píše na tu velmi-velmi-pseudo náhodnou adresu kam to ukazuje.
    Nedal;s NULL, a řekl's že na té adrese je 100 char-ů alokovaných, tak se to tam zapíše.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    martin-ux avatar 5.1.2014 00:11 martin-ux | skóre: 18 | Bratislava
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    nie je tak pravda .. getcwd ho alokuje, ked je NULL. az teraz som pochopil, co sa OP pyta.

    takto je to ok:
    int main() {
    	char* buf = NULL;
    	buf = getcwd(buf, 100);
    
    	printf ("buf: %s\n", buf);
    
    	free(buf);
    	buf = NULL;
    
    	return 0;
    }
    buf musi byt NULL aby sa alokoval novy space. ak je not NULL, tak getcwd() to bere ako pointer na alokovany space.

    src: FreeBSD: /usr/src/lib/libc/gen/getcwd.c:
    
        90		} else {
        91			if ((pt = malloc(ptsize = PATH_MAX)) == NULL)
        92				return (NULL);
        93			ept = pt + ptsize;
    
    kde pt je prvy arg. fcie.
    ..when you do things right, people won't be sure you've done anything at all..
    5.1.2014 16:20 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    Ano, tak to je. A co není pravda?
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    martin-ux avatar 5.1.2014 16:51 martin-ux | skóre: 18 | Bratislava
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    nedaju sa editovat prispevky, chcel som napisat "nie je to tak celkom pravda". tym som chcel reagovat na:
    nikdo nic nealokuje
    ze v tomto pripade getcwd() alokuje za neho buffer, ak je vstupny argument pre buf NULL.
    ..when you do things right, people won't be sure you've done anything at all..
    5.1.2014 17:09 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    Ju, už mi to pomalu došlo, to je jen nedorozumění.
    »nikdo nic nealokuje« jsem myslel v tom původním případě, tedy tehdy pokud není ukazatel inicializovaný (na NULL nebo na alokovanou paměť).
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    martin-ux avatar 5.1.2014 19:31 martin-ux | skóre: 18 | Bratislava
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    jj, sme sa nerozumeli :).
    ..when you do things right, people won't be sure you've done anything at all..
    4.1.2014 23:30 majkl
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    protoze nahoda? pustit to treba jindy/jinde, zas to pokazdy zhavaruje
    martin-ux avatar 4.1.2014 23:55 martin-ux | skóre: 18 | Bratislava
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    velmi vela, hodne dobrych FAQs na jednom mieste aj s vysvetlenim tu, tvoj problem tu
    ..when you do things right, people won't be sure you've done anything at all..
    5.1.2014 10:57 potato
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    Kód nefunguje správně. S tvou verzí kompilátoru, architekturou, volbami při kompilaci, ..., etc. se náhodou předá getcwd() vhodný první argument.

    Proměnné na zásobníku jsou neinicializovaná. Když je neinicializovaný buff náhodou NULL, tak getcwd() alokuje paměť. To je ten případ, kdy si myslíš, že to funguje.

    Když něco přidáš, tak to dopadne tak (opět náhodou), že neinicializovaný buff už není NULL -- a getcwd() tedy dostane ukazatel někam doprčic a program spadne.
    5.1.2014 19:11 Program
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku
    Ač trochu nesrozumitelně, ale už byla asi většina věcí vysvětlená. Jen bych trochu upřesnil, že ačkoli getpwd při NULL pointeru inteligentně alokuje pamět, nealokuje ji na zásobníku, ale na haldě, takže se vždy musí uvolnit pomocí free, jinak vzniká tzv. memory leak. Nastudujte si, jak to funguje, jinak nic v C nenaprogramujete (všechno bude dřív nebo později padat)
    14.1.2014 17:16 Nikola Pajkovský | skóre: 16
    Rozbalit Rozbalit vše Re: C ukazatel přetečení zásobníku

    As an extension to the POSIX.1-2001 standard, Linux (libc4, libc5, glibc) getcwd() allocates the buffer dynamically using malloc(3) if buf is NULL. In this case, the allocated buffer has the length size unless size is zero, when buf is allocated as big as necessary. The caller should free(3) the returned buffer.

    #include <linux/limits.h>
    
    /* ... includes ...*/
    
    char *buf = NULL;
    buf = getcwd(buf, PATH_MAX);
    
    nebo
    #include <linux/limits.h>
    
    /* ... includes ...*/
    
    char buf[PATH_MAX];
    buf = getwd(buf, sizeof(buf));
    
    Save the whales. Feed the hungry. Free the mallocs

    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.