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 14:22 | Nová verze

Po 4 měsících vývoje od vydání verze 3.0.0 byla vydána nová verze 3.1.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 189 vývojářů. Provedeno bylo více než 1 900 commitů. Přehled úprav a nových vlastností v seznamu změn.

Ladislav Hagara | Komentářů: 0
dnes 01:32 | Nová verze

Letos bylo v komunitě Mageia hodně změn. Po volbě nových vedoucích přišla velká aktualizace a krátce na to udržovací verze 6.1. 7.12., dle plánu, vyšla Mageia s číslem 7 v její první beta verzi. Chyby můžete hlásit v bugzille. Chyby v českých překladech pak na fóru české komunity.

Joelp | Komentářů: 0
dnes 00:11 | Zajímavý projekt

Kvůli rychlejšímu vývojovému cyklu byla přemístěna Cinelerra-gg. Cinelerra-gg je fork Cinelerry-hv. Některé rozdíly forků popisuje sám hlavní vývojář William Morrow (aka GoodGuy). Není zde popsán i fork Lumiera, zřejmě kvůli zatím nepoužitelnému stavu.

… více »
D81 | Komentářů: 0
včera 19:11 | Nová verze

Do aplikace pro instant messaging Telegram (Wikipedie) lze nově nahrát češtinu. Více v příspěvku na blogu Telegramu.

Ladislav Hagara | Komentářů: 5
včera 10:55 | Nová verze

Jean-Baptiste Kempf, prezident neziskové organizace VideoLAN stojící za svobodným multiplatformním multimediálním přehrávačem a frameworkem VLC, oznámil v příspěvku na svém blogu vydání první oficiální verze 0.1.0 v říjnu představeného dekodéru svobodného videoformátu AV1 (AOMedia Video 1) s názvem dav1d (Dav1d is an AV1 Decoder). Jedná se o alternativu k referenčnímu dekodéru libaom. Kódový název dav1da verze 0.1.0 je Gazelle.

Ladislav Hagara | Komentářů: 2
včera 10:22 | Nová verze

Po více než dvou letech od vydání verze 11.0 byla vydána nová major verze 12.0 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 4
11.12. 19:55 | Nová verze

Byla vydána verze 3.11 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Řešena je řada bezpečnostních chyb.

Ladislav Hagara | Komentářů: 0
11.12. 15:22 | Nová verze

Byl vydán Mozilla Firefox 64.0. Přehled novinek v poznámkách k vydání a na stránce věnované vývojářům. Nejnovější verze tohoto webového prohlížeče přináší například ovládání více panelů, nebo správce úloh, který lze otevřít v nabídce Firefoxu > Více > Správce úloh, nebo napsáním about:performance do adresního řádku.

Ladislav Hagara | Komentářů: 8
11.12. 13:00 | Zajímavý článek Ladislav Hagara | Komentářů: 0
10.12. 22:33 | Nová verze

Po 3 měsících vývoje od vydání verze 14 byla vydána nová stabilní verze 15 open source systému Nextcloud, forku ownCloudu, umožňujícího provoz vlastního cloudového úložiště. Přehled novinek i s náhledy v příspěvku na blogu. Pro vyzkoušení Nextcloudu je k dispozici demo.

Ladislav Hagara | Komentářů: 6
Chystáte se přejít na Wayland na „desktopu“?
 (26%)
 (6%)
 (12%)
 (32%)
 (25%)
Celkem 120 hlasů
 Komentářů: 14, poslední 10.12. 12:19
Rozcestník

Dotaz: Ukazatele v C

2.3.2006 15:22 Jiří Daněk | skóre: 12 | blog: muj_blogisek
Ukazatele v C
Přečteno: 335×
Dobrý den. Chtěl bych se zeptat, proč tento kód provede bez chyb:

void main(void)
{
int *p;
p = (int *) malloc(sizeof(int *) * 5);
p[2]=10;
p[50]=11;
printf("%d", p[50]);
free(p);
}
A jak by se, prosím vás, dalo toto zapsat správně? Díky.
Byl jeden pán a ten měl psa. HAFUŠA se jmenoval.

Odpovědi

2.3.2006 15:44 Kyosuke | skóre: 28 | blog: nalady_v_modre
Rozbalit Rozbalit vše Re: Ukazatele v C
Provede se "správně" v tom smyslu, že to náhodou funguje. Jestli to chápu správně, příslušné systémové volání kernelu přiděluje procesu paměť de facto po násobcích stránek - částečně stránku přidělit nemůže. Ten pointer se trefí do části přidělené systémovým voláním, ale nikoli do oblasti zaregistrované jako přidělené pomocí standardní funkce malloc. Takže kernel OS si ničeho nevšimne a malloc/free mechanismus o těch datech přehled taky nemá.

A že to náhodou funguje nemusí znamenat, že to bude fungovat vždy a všude. ;-)
2.3.2006 15:44 Jirka
Rozbalit Rozbalit vše Re: Ukazatele v C
1. Nejsem si jistý, zda to nepatří do jiného fóra než do Linuxu.

2. Otázka je nějak divně formulována. Nejdřív se ptáte, "proč tento kód provede bez chyb", pak "jak by se toto dalo zapsat spravně". Moc tomu nerozumím. Otázka o správnosti úzce souvisí i s tím, co to má dělat. To taky není jasné.

3. Pointer p ukazuje na int, ale alokujete pamět na 5 ukazatelů na int, nikoliv na 5 integerů.

4. Ochrana přístupu do oblasti mimo alokovanou paměť je asi věcí systému. Takže patrně záleží i na tom, pod čím to pouštíte.

Jirka
2.3.2006 20:53 trekker.dk | skóre: 71
Rozbalit Rozbalit vše Re: Ukazatele v C
3. Pointer p ukazuje na int, ale alokujete pamět na 5 ukazatelů na int, nikoliv na 5 integerů.
Na většině systémů jsou oba typy 32bitové, takže žádný problém.
Quando omni flunkus moritati
2.3.2006 21:01 finn | skóre: 42 | blog: finnlandia | 49° 44´/13° 22´
Rozbalit Rozbalit vše Re: Ukazatele v C
Tím hůř. Hledat chybu, která se projevuje jen při konjunkci Jupiteru s Marsem, je nezáviděníhodný úkol.
Užívej dne – možná je tvůj poslední.
2.3.2006 21:40 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Ukazatele v C
To nebylo příliš povedené ani jako vtip. Pokud jste to náhodou myslel vážně, mohu vám poradit jediné: neprogramujte, a neposlechnete-li mne, aspoň své výtvory nezveřejňujte.
2.3.2006 22:21 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
Rozbalit Rozbalit vše Re: Ukazatele v C
Jsou jazyky kde by mu to nebylo dovoleno (nebo spíš, kde by něco takového nemělo smysl dělat), tak ohledně programování není ještě nic ztraceno ;-)
Copak toho není dost?
2.3.2006 23:12 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Ukazatele v C
Tady jde spíš o přístup, s takovým by ho nezachránil ani Karel…
2.3.2006 23:43 trekker.dk | skóre: 71
Rozbalit Rozbalit vše Re: Ukazatele v C
Na většině systémů jsou oba typy 32bitové, takže žádný problém při překladu a spuštění na platformě x86 nenastane

Pokud si myslíte, že tím jsem chtěl tvrdit, že ten zápis je programátorsky v pořádku, tak nechtěl

Suma sumárum k té vaší radě - trhněte si nohou !
Quando omni flunkus moritati
3.3.2006 00:20 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Ukazatele v C
Nohou si netrhnu. Už to tu padlo jednou, ale asi je třeba to zopakovat: program, který většinou funguje, je daleko nebezpečnější, než program, který nefunguje skoro nikdy.
3.3.2006 00:24 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
Rozbalit Rozbalit vše Re: Ukazatele v C
Ale zase je aspoň nějaká šance že občas udělá co má :-)

(já jenom tak rejpu, původně jsem pouze naznačoval, že ačkoliv to samozřejmě chyba je, tak na řešený problém to nejspíše vliv nemá)
Copak toho není dost?
3.3.2006 00:32 trekker.dk | skóre: 71
Rozbalit Rozbalit vše Re: Ukazatele v C
Otázka zněla, proč se daný kód provede bez chyb. Odpověď: protože na dnešních x86 sizeof(int) == sizeof(int*). Za tímhle tvrzení si stojím. Tečka.
#include <stdio.h>

int main (void) {
 printf ("%i, %i\n", sizeof(int), sizeof(int*));
 return 0;
 }

#gcc -o sizeof -Wall -pedantic sizeof.c
#./sizeof
4, 4
#
Nikdy jsem netvrdil, že ten zápis v otázce je dobře nebo dokonce že by se to tak mělo dělat. Nikdy jsem netvrdil, že přístup "na x86 to bude fungovat, tak to tak nechám" je správný. Proto mi ani nemusíte opakovat, že
program, který většinou funguje, je daleko nebezpečnější, než program, který nefunguje skoro nikdy.
Opravdu nemusíte. Vím to sám.
Quando omni flunkus moritati
Viliam Púčik avatar 2.3.2006 15:52 Viliam Púčik | skóre: 22 | blog: minimal
Rozbalit Rozbalit vše Re: Ukazatele v C
Takto sa ti program sice skompiluje, ale urcite nepracuje spravne....
#include <stdio.h>
#include <stdlib.h>

int main(void)
{
	int *p;
	p = (int *) malloc(sizeof(int *) * 5);
	p[2]=10;	
	p[50]=11;
	printf("%d", p[50]);
	free(p);
	
	return 0;
}

V prvom rade su dost podozrive nasledujuce prikazy:
p = (int *) malloc(sizeof(int *) * 5);
p[2]=10;
Vytvoril si si totiz volnu pamat velkosti (5*smernik na int) a nasledne zapisujes do tohto pola ako by to bolo pole intov. Pravdepodobne to malo vyzarat takto:
p = (int *) malloc( sizeof(int) * 5 );
Takisto tu je problem s tym, ze zapisujes na miesto, ktore ti takpovediac nepatri (p[50]=11;)...
Normalny program by vyzeral asi takto:
#include <stdio.h>
#include <stdlib.h>

int main(void)
{
	int *p;
	p = (int *) malloc( sizeof(int) * 51 );
	p[2]=10;	
	p[50]=11;
	printf("%d", p[50]);
	free(p);
	
	return 0;
}
Viliam Púčik avatar 2.3.2006 15:54 Viliam Púčik | skóre: 22 | blog: minimal
Rozbalit Rozbalit vše Re: Ukazatele v C
Ako pozeram, uz to tu niekto predo mnou napisal. Asi som si zabudol reloadnut stranku...
2.3.2006 15:57 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
Rozbalit Rozbalit vše Re: Ukazatele v C
No, jenže vzhledem k tomu, že ukazatel na int a int mají třeba u mě shodnou velikost čtyř bajtů, tak to na funkčnost programu přímý vliv nějak extra asi mít nebude :-)
Copak toho není dost?
Viliam Púčik avatar 2.3.2006 16:08 Viliam Púčik | skóre: 22 | blog: minimal
Rozbalit Rozbalit vše Re: Ukazatele v C
... tak to na funkčnost programu přímý vliv nějak extra asi mít nebude :-)

Skompiluj to pod inym kompilatorom (GCC/...) alebo pod inym systemom (Linux/Wind32/Win16/...) alebo pod inou platformou a uvidis aky to bude mat extra vplyv ;-)
2.3.2006 16:15 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
Rozbalit Rozbalit vše Re: Ukazatele v C
No samozřejmě :-) Ale u tazatele čekám podmínky dost podobné. A i kdyby, tak to bude třeba dvakrát víc nebo půlka, to ještě není tak hrozné :-)
Copak toho není dost?
2.3.2006 18:44 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Ukazatele v C
Bylo by to celkem vtipné, kdyby stejně neuvažovala spousta programátorů a kdyby podle této logiky nepsali své aplikace…
2.3.2006 19:02 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
Rozbalit Rozbalit vše Re: Ukazatele v C
Zase si představte svět, kde by se všechno na první pokus zkompilovalo a i běželo bez chyb, kdo by tam chtěl žít? ;-)
Copak toho není dost?
2.3.2006 21:41 Michal Kubeček | skóre: 71 | Luštěnice
Rozbalit Rozbalit vše Re: Ukazatele v C
Lidé, kteří mají u producentů distribucí na starosti balíčkování? :-)
2.3.2006 15:56 podlesh | skóre: 38 | Freiburg im Breisgau
Rozbalit Rozbalit vše Re: Ukazatele v C
Zásada č.I: zapni všechny warningy (-Wall)

Zásada č.II: vždy používej nějaký malloc debugger.

Jedním z nejjednodušších je electric fence, stačí jen přilinkovat k binárce -lefence . Nedělá nic jiného než že zajistí, že takto špatně napsaný program spolehlivě chcípne na SIGSEGV (jak se sluší a patří).
Josef Kufner avatar 2.3.2006 19:33 Josef Kufner | skóre: 68
Rozbalit Rozbalit vše Re: Ukazatele v C
Tohle je ideální pro výlet do krajin obývaných démony, draky a coredumpy...

Tím že něco napíšeš do paměti, kterou ti sice systém věnoval, ale nemáš zaručeno co tam je nebo bude, si fakt koleduješ o opravdu divné chování programu a okamžitý segfault je to nejlepší co tě v tomhle případě může potkat. To že to náhodou funuje je asi ta nejhorší varianta.

Jakmile napíšeš něco většího, tak si tímhle přepíšeš data, která můžou patřit čemukoliv a například pokud si přepíšeš pár byte za alokovanou pamětí tak se jí obvykle nepovede uvolnit, protože malloc tam má něco uloženého... nebo si přepíšeš nějakou drobnost a třeba GTK si pak při odebrání posledního widgetu z hboxu bude hrát na ospalou a bude kašlat na další data přicházející z unixového socketu, který se inicializuje úplně někde jinde a vlastně s ním gtk ani nic nedělá...
Hello world ! Segmentation fault (core dumped)
3.3.2006 15:44 Jiří Daněk | skóre: 12 | blog: muj_blogisek
Rozbalit Rozbalit vše Re: Ukazatele v C
Mě spíš trápí rápí ten zápis do nalokované paměti (i[55] =5;). To by mi přece nemělo být dovoleno. A měl bych ještě jeden kousek podivného malloc kódu načítajícího soubor do pole:

char **pole;
scena = fopen( "./config/scena.txt" , "rt");
pole = (char **)malloc(sizeof(char*));
char buffer[512];
while(fscanf(scena, "%s",&buffer) != EOF){
pole[i] = (char *)malloc(sizeof(char) * strlen(buffer));
strcpy(pole[i], buffer);
i++;
}

Já si myslím, že to nemůže fungovat, ale funguje, a dokonce spolehlivě (hru obsahující toto jsem spustil tak stokrát).
Byl jeden pán a ten měl psa. HAFUŠA se jmenoval.
3.3.2006 15:49 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
Rozbalit Rozbalit vše Re: Ukazatele v C
To je v nějakým veřejně dostupným OSS projektu? Abych se tomu zdaleka vyhnul :-)
Copak toho není dost?
3.3.2006 15:55 Jiří Daněk | skóre: 12 | blog: muj_blogisek
Rozbalit Rozbalit vše Re: Ukazatele v C
Ne. Je to moje dílko. Tedy už se to tam nevyskytuje :-).
Byl jeden pán a ten měl psa. HAFUŠA se jmenoval.
Josef Kufner avatar 3.3.2006 15:57 Josef Kufner | skóre: 68
Rozbalit Rozbalit vše Re: Ukazatele v C
Fungovat to za nekterych okolnosti bohuzel bude. Jde o to, ze se pamet alokuje po blocich a pokud je mez pole prekrocena jen o kousek, tak to projde. Ovsem je tu jiny problem, o kterem jsem uz psal: nikdo nevi co tam je a co se tim prepise. Muze to byt nevyuzite misto a je to v pohode, ale taky to muze byt kus kodu nebo jina data programu a pak je to horsi nez vylet do rise divu...
Hello world ! Segmentation fault (core dumped)
3.3.2006 16:00 VícNežNic | skóre: 42 | blog: Spáleniště | Ne dost daleko
Rozbalit Rozbalit vše Re: Ukazatele v C
Tohle mi funguje spolehlivě :-)
void main (void) {
        printf ("%d\n", sbrk (0));
        int *p = (int *) malloc (sizeof (int) * 10);
        printf ("%d\n", sbrk (0));
        int *i = (int *) sbrk (0);
        printf ("Tohle je jeste moje\n");
        *(i - 1) = 100;
        printf ("Tohle uz ne a nastane konec :-)\n");
        *i = 100;
}
Copak toho není dost?
3.3.2006 16:01 trekker.dk | skóre: 71
Rozbalit Rozbalit vše Re: Ukazatele v C
Kyosuke to popisuje hned v prvním příspěvku. Paměť je přidělována po stránkách, takže ten program sice píše mimo alokované pole, ale stále do "své" stránky, takže žádný segfault.

Problém nastane, když se při nějaké další alokaci zabere zbytek té stránky něčím jiným, a volání typu i[55] = 5 to přepíše - pak se program bude chovat zcela nevypočitatelně.
Quando omni flunkus moritati

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.