====== Práce s binárními soubory ====== * [[dox>prace-s-binarnimi-soubory/jednotkove-vektory.c|Jednotkové_vektory]] * [[dox>prace-s-binarnimi-soubory/database-osob.c|Databáze_osob]] Veškeré níže uvedené funkce je možné použít také s textovými soubory, mnohem častěji se však v praxi využívají u souborů binárních. ======Čtení bloku dat: fread====== Hlavička funkce [[die.net>3/fread]] <code c> size_t fread(void *kam, size_t rozmer, size_t pocet, FILE *fr); </code> kde * //fr// je datový proud, ze kterého se čte, * //rozmer// je velikost jedné čtené položky, * //pocet// udává počet položek a * //kam// je adresa, kam se úspěšně přečtená data uloží. Funkce vrací počet úspěšně přečtených položek. Příklad: <code c> #define VELIKOST_BLOKU 10 ... int data[VELIKOST_BLOKU]; FILE *fr = fopen("in.dat", "rb"); fread(data, sizeof(int), VELIKOST_BLOKU, fr); </code> ======Zápis bloku dat====== Hlavička funkce: <code c> size_t fwrite(void *odkud, size_t size, size_t nmemb, FILE *fw); </code> kde * //fw// je datový proud, do kterého se zapisuje, * //size// je velikost jedné zapisované položky, * //nmemb// udává počet položek a * //odkud// je adresa, kde jsou zapisovaná data uložena ([[promenna#buffer]]). Funkce vrací počet úspěšně zapsaných položek. Příklad: <code c> #define VELIKOST_BLOKU 10 ... int data[VELIKOST_BLOKU]; FILE *fw = fopen("out.dat", "wb"); ... fwrite(data, sizeof(int), VELIKOST_BLOKU, fw); </code> ======Posun pozice v souboru====== V některých situacích je třeba číst (resp. zapisovat) data z (resp. do) konkrétního místa souboru. Toto nám jazyk C umožňuje řešit pomocí posouvání "ukazatele" na aktuálně zpracovávanou pozici daného souboru. Hlavička funkce [[die.net>3/fseek]] pro posun v souboru: <code c> int fseek(FILE *f, long offset, int odkud); </code> kde * //f// je daný soubor, * //offset// udává počet bytů (může být i záporné číslo), o kolik se chceme posunout směrem ke konci souboru, * //odkud// udává pozici v souboru, ke které se bude zamýšlený posun vztahovat. Parametr odkud může nabývat těchto hodnot: * SEEK_SET (pro posun od začátku souboru), * SEEK_CUR (pro posun od aktuální pozice) a * SEEK_END (posun od konce souboru). Funkce vrací nulu v případě úspěchu a nenulovou hodnotu, pokud nastala chyba. Hlavička funce pro zjištění pozice: <code> long ftell(FILE *f); </code> kde f je daný soubor. Funkce vrací aktuální pozici odpovídající velikosti posunu od začátku souboru v bytech. Příklad: <code c> /* navrat na puvodni misto */ akt_pos = ftell(f); fseek(f, 0L, SEEK_SET); if (hledej(f, "ahoj") == NULL) fseek(f, akt_pos, SEEK_SET); </code> Pokud v programu zapisujeme a čteme z téhož souboru, je potřeba si uvědomit, že z technických důvodů nesmí žádná vstupní operace (např. volání fread) následovat přímo po výstupní operaci (např. volání fwrite) a naopak, bez předchozího volání funkce fseek. Pokud není potřeba měnit pozici v souboru, lze pomocí funkce realizovat posun o 0 bytů (např. fseek(f, 0L, SEEK_CUR);). ---- cc,upol