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 17:25 | IT novinky

Do prodeje (Farnell) se dostal jednodeskový počítač Tinker Board (unboxing). Jedná se o konkurenci Raspberry Pi 3 od společnosti Asus. Porovnání (jpg) těchto počítačů například na CNXSoft. Cena Tinker Boardu je 55 £.

Ladislav Hagara | Komentářů: 0
dnes 14:44 | Zajímavý projekt

Byla zveřejněna pravidla hackerské soutěže Pwn2Own 2017, jež proběhne od 15. do 17. března v rámci bezpečnostní konference CanSecWes ve Vancouveru. Soutěžit se bude o více než milion dolarů v pěti kategoriích. Letos se bude útočit i na Ubuntu. Jedná se již o 10. ročník této soutěže.

Ladislav Hagara | Komentářů: 1
dnes 13:33 | Nová verze

Po sedmi měsících vývoje od vydání verze 5.7 byla vydána verze 5.8 (YouTube) toolkitu Qt. Z novinek lze zmínit například Qt Lite pro vestavěná zařízení. Nově jsou plně podporovány moduly Qt Wayland Compositor (YouTube) a Qt SCXML (YouTube). Současně byla vydána verze 4.2.1 integrovaného vývojového prostředí (IDE) Qt Creator.

Ladislav Hagara | Komentářů: 0
dnes 11:52 | Pozvánky

Lednový Prague Containers Meetup se koná ve čtvrtek 26. ledna 2017 od 18:00 v Apiary, Pernerova 49, Praha 8. Přijďte se podívat na přednášky o Enterprise Kubernetes a Jenkins as a code.

little-drunk-jesus | Komentářů: 0
dnes 11:40 | Pozvánky

Program letošního ročníku konference Prague PostgreSQL Developer Days, která se koná již 15. a 16. února 2017 na ČVUT FIT, Thákurova 9, Praha 6, byl dnes zveřejněn. Najdete ho na stránkách konference včetně anotací přednášek a školení. Registrace na konferenci bude otevřena zítra (24. ledna) v brzkých odpoledních hodinách.

TomasVondra | Komentářů: 0
včera 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

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

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
21.1. 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
21.1. 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

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

Dotaz: Ukazatele v C

2.3.2006 15:22 Jiří Daněk | skóre: 12 | blog: muj_blogisek
Ukazatele v C
Přečteno: 331×
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 | Praha
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: 66
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: 66
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.