Portál AbcLinuxu, 13. května 2025 23:23

Dotaz: rychlost write() a puts()

3.6.2005 14:12 Martin Tůma | skóre: 39 | blog: RTFM | Praha
rychlost write() a puts()
Přečteno: 86×
Odpovědět | Admin

Může mi někdo vysvětlit, proč jsou operace provedené na souborech otevřených pomocí open() mnohem pomalejší než operace prováděné se soubory otevřenými pomocí fopen()? (Oboje dvoje na obyčejných souborech)

Případně pokuď existuje, tak bych uvítal nějaký "trik" jak dosáhnout stejné rychlosti.

Každý má právo na můj názor!
Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

3.6.2005 14:28 unchallenger | skóre: 69 | blog: unchallenger
Rozbalit Rozbalit vše Re: rychlost write() a puts()
Odpovědět | | Sbalit | Link | Blokovat | Admin
Pomalejší rozhodně nejsou, ale záleží na tom, co děláš. Nejspíš s těmi soubory zacházíš tak, že je pro tebe bufferování v stdio velmi výhodné.
3.6.2005 15:15 Martin Tůma | skóre: 39 | blog: RTFM | Praha
Rozbalit Rozbalit vše Re: rychlost write() a puts()

Hmm, takže s tím očividně neumím zacházet... Proč může být druhý kód mnohonásobně pomalejší než první?

kód 1 - fopen

	/* Hlavicka */

	if(!fwrite(&header, sizeof(header), 1, fp))
		return 0;
	
	/* Data */
	
	if((fr = fopen(file_name, "r")) == NULL)
		return 0;

	while(c = getc(fr), !feof(fr))
		putc(c, fp);

	if(fclose(fr) == EOF)
		return 0;

kód 2 - open

	/* Hlavicka */

	if(write(fp, &header, sizeof(header)) != sizeof(header))	
		return 0;

	/* Data */
	
	if((fr = open(file_name, O_RDONLY)) == -1)
		return 0;

	while(read(fr, &c, 1) > 0)
		write(fp, &c, 1)
			
	if(close(fr) == -1)
		return 0;

fp je deskriptor normálního otevřeného souboru, v prvnim případě FILE *, ve druhém int.

Program ve kterém to potřebuju použít by měl bejt obdobou tar -cvvzf. Potřeboval bych proto vytvořený archiv po znaku rovnou posílat pomocí roury komprimátoru, ale pomocí write() a read() je to strašně pomalý - tak, že mnohem rychlejší je nejdříve vytvořit archiv a pak ho znova načítat a komprimovat...

Každý má právo na můj názor!
3.6.2005 15:22 0
Rozbalit Rozbalit vše Re: rychlost write() a puts()

Co zkusit ve druhem pripade misto jednoho znaku treba 1000?:

char pole[1000];
while(read(fr,pole,1000))
    write(fp,pole,1000);

Duvod je ten, ze kdyz jedes znak po znaku, tak pro kazdou operaci pouzijes jedno preruseni a to bez ohledu na to, kolik mas dat, takze procesor se musi porad starat o preruseni misto toho aby dal prikaz pameti/disku, ze ma neco udelat.

3.6.2005 15:28 Martin Tůma | skóre: 39 | blog: RTFM | Praha
Rozbalit Rozbalit vše Re: rychlost write() a puts()

To mě taky napadlo, ale pro LZW kompresy potřebuju ty znaky pak dostávat stejně po znaku (šlo by si ale udělat nějakej buffer). Nicméně proč je to pomocí fputs() "normálně" rychlý a pomocí write() tak pomalý?

Každý má právo na můj názor!
3.6.2005 15:40 unchallenger | skóre: 69 | blog: unchallenger
Rozbalit Rozbalit vše Re: rychlost write() a puts()
Protože write() je sycall, kdežto fputc() je téměř vždy triviální operace přidání znaku do nějakého bufferu, jen jednou za čas se něco zapíše. Ostatně na fputc() nejvíc sežere zamykání, fputc_unlocked() už je úplně triviální.
3.6.2005 15:41 Michal Marek (twofish) | skóre: 55 | blog: { display: blog; } | Praha
Rozbalit Rozbalit vše Re: rychlost write() a puts()
Protože fputs bufferuje, takže buď používej stdio, nebo si napiš vlastní funkci, která bude dělat totéž.
3.6.2005 15:43 podlesh | skóre: 38 | Freiburg im Breisgau
Rozbalit Rozbalit vše Re: rychlost write() a puts()
Takže potřetí, trochu polopatičtěji: funkce pracující s descriptorem (open, read, write) jsou low=level, přímo provádějí operaci. Funkce ktere pracují s FILE strukturou provádějí buffering. Při čtení/zápisu po jednom byte má opravdu velký význam (a to je důvod proč tam je).
3.6.2005 15:56 martin
Rozbalit Rozbalit vše Re: rychlost write() a puts()
tak to už máme putc(), puts() a + ještě fputs(). m.

Založit nové vláknoNahoru

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

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.