Table of Contents

7 - Spojové struktury, práce se soubory

* pro vyučující: 07

Zapůjčení desek Nucleo STM32F446RE pro domácí seznámení s připojením a programování na platformě https://developer.mbed.org/platforms/ST-Nucleo-F446RE/.

Procvičovaná témata

Úkoly na cvičení

  1. Implementujte frontu, která bude obsahovat celá čísla, která bude uživatel zadávat z klávesnice.
    1. Společně s cvičícím navrhněte vhodnou datovou stukturu, na které bude fronta založena.
    2. Společně s cvičícím navrhněte prototypy funkcí, které umožní vkládání dat do fronty (PUSH), odebírání z fronty (POP), dotaz na poslední prvek.
    3. Vytvořte funkci, která vypíše na konzoli obsah celé fronty.
    4. Nezapomeňte implementovat i funkci, která uvolní všechna data spojená s implementovanou frontou.
    5. Kontrolujte správnost dynamické alokace paměti pomocí Valgrindu.
  2. Upravte vhodně kód tak, abyste naimplementovali zásobník.
    1. S cvičícím diskutujte změny, které jste v kódu provedli.

Další úkoly na procvičení

  1. Implementujte spojový seznam, který v sobě bude obsahovat vždy dvojici dat - dvě celá čísla - první bude datová složka a druhé bude představovat prioritu.
  2. Upravte předchozí seznam tak, aby implementoval prioritní frontu tak, aby funkce PUSH od začátku vytvářela vnitřní stukturu seznamu seřazenou podle priority.

Práce se soubory

FILE *fopen(const char *path, const char *mode);
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
size_t fwrite(const void *ptr, size_t size, size_t nmemb, FILE *stream);

Úkoly

struct test {
    int ival;
    char cval;
};
typedef struct test test_t;

struct test2 {
    int ival;
    char cval;
    char *str;
};
typedef struct test2 test2_t;

__attribute__((packed))

uint32_t le_to_be(uint32_t v);