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:44 | IT novinky

    Apple bez varování odstranil ze svého obchodu sociální síť VKontaktě i další aplikace skupiny VK, jako je VK Music nebo VK Video [Novinky.cz].

    Ladislav Hagara | Komentářů: 0
    dnes 14:22 | IT novinky

    V dubnu loňského roku představený poštovní klient Notion Mail bude 22. září ukončen.

    Ladislav Hagara | Komentářů: 2
    dnes 04:33 | Komunita

    Konference OpenAlt 2026 hledá přednášející. Proběhne o víkendu 7. a 8. listopadu na půdě Fakulty informačních technologií VUT v Brně. Témata konference jsou: Otevřený a svobodný software, IoT a Hnutí tvůrců, Vzdělávání, Bezpečnost a soukromí, Otevřená společnost, komunity a data, OpenMobility a další.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | IT novinky

    Společnosti OpenAI a Broadcom oznámily čip optimalizovaný pro AI pojmenovaný Jalapeño.

    Ladislav Hagara | Komentářů: 0
    včera 20:22 | Nová verze

    Deno (Wikipedie), běhové prostředí (runtime) pro JavaScript, TypeScript a WebAssembly, bylo vydáno v nové verzi 2.9. Hlavní novinkou je deno desktop pro převod Deno projektu na desktopovou aplikaci. Jedná se o alternativu k frameworkům Electron nebo Tauri.

    Ladislav Hagara | Komentářů: 2
    včera 15:44 | IT novinky

    Od zítra jsou Datové schránky oficiálně na nové adrese datovka.gov.cz. Adresa mojedatovaschranka.cz zůstává funkční do 27. srpna 2026, následně budou uživatelé automaticky přesměrováni na datovka.gov.cz.

    Ladislav Hagara | Komentářů: 3
    včera 13:44 | Nová verze

    Dolphin (Wikipedie), tj. open source multiplatformní emulátor herních konzolí GameCube a Wii od Nintenda, byl vydán ve verzi 2606. S podporou Game Boy Playeru.

    Ladislav Hagara | Komentářů: 0
    včera 11:11 | Zajímavý software

    Vasudeva Kamath představil utilitu debvulns, alternativu k nativní utilitě debsecan, pro výpis zranitelností v Debianu. Navíc má především možnost výstupu ve strukturovaných formátech JSON a CSV. V plánu je exportér pro Prometheus.

    Ladislav Hagara | Komentářů: 0
    24.6. 21:44 | IT novinky

    Oficiální český státní eshop s elektronickými dálničními známkami nově najdete na edalnice.gov.cz. Doména gov.cz jasně potvrzuje, že jste na oficiálním státním webu [𝕏].

    Ladislav Hagara | Komentářů: 27
    24.6. 14:22 | Nová verze

    Byla vydána nová verze 4.8.0 interaktivního shellu fish (friendly interactive shell, Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 6
    Které desktopové prostředí na Linuxu používáte?
     (11%)
     (8%)
     (2%)
     (17%)
     (31%)
     (3%)
     (6%)
     (2%)
     (15%)
     (26%)
    Celkem 1991 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Administrace komentářů

    Jste na stránce určené pro řešení chyb a problémů týkajících se diskusí a komentářů. Můžete zde našim administrátorům reportovat špatně zařazenou či duplicitní diskusi, vulgární či osočující příspěvek a podobně. Děkujeme vám za vaši pomoc, více očí více vidí, společně můžeme udržet vysokou kvalitu AbcLinuxu.cz.

    Příspěvek
    11.8.2021 00:37 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: fread binárního souboru 16bit dat do 32bitového pole
    Mezikrok v podobě 16bit pole samozřejmě funguje, ale raději bych tolik neplýtval pamětí.

    Huh? Vždyť není třeba nikde plýtvat pamětí:

    void stretch16b32b(void* array, size_t size) {
      const uint16_t *input = (uint16_t*)array + size - 1;
      uint32_t *output = (uint32_t*)array + size - 1;
      while (output >= (uint32_t*)array) { *output-- = *input--; }
    }
    

    Tady je totéž v nějakém kontextu:

    #include <errno.h>
    #include <stddef.h>
    #include <stdint.h>
    #include <stdio.h>
    #include <stdlib.h>
    
    static void stretch16b32b(void* array, size_t size) {
      const uint16_t *input = (uint16_t*)array + size - 1;
      uint32_t *output = (uint32_t*)array + size - 1;
      while (output >= (uint32_t*)array) { *output-- = *input--; }
    }
    
    static int try_close(FILE *f) {
      int errors = 0;
      if (ferror(f)) { fputs("Read error\n", stderr); ++errors; }
      if (fclose(f)) { perror("Close error"); ++errors; }
      return errors;
    }
    
    static int fread16b(const char* file, void *array, size_t size) {
      FILE *const f = fopen(file, "r");
      if (!f) { perror("Open error"); return 0x1; }
      size_t items = fread(array, sizeof(uint16_t), size, f);
      if (items != size) {
        fputs("Too few elements or read error\n", stderr);
        return 0x2 + try_close(f);
      }
      if (fread(array, 1, 1, f)) { fputs("Input too long\n", stderr);
                                   return 0x4 + try_close(f); }
      if (!feof(f)) { fputs("This must not happen\n", stderr);
                      return 0x6 + try_close(f); }
      const int retval = try_close(f);
      if (retval) { return 0x8 + retval; }
      return 0;
    }
    
    static size_t readuint(const char *input, int *error) {
      char *end;
      errno = 0;
      const size_t result = strtoul(input, &end, 10);
      if (errno) { perror("Invalid number\n"); ++*error; return 0; }
      if (*end || input == end) { fputs("Invalid number\n", stderr);
                                  ++*error; return 0; }
      return result;
    }
    
    int main(int argc, const char *const *argv) {
      if (argc != 3) {
        fprintf(stderr, "Usage: %s <number of shorts> "
                        "<input file>\n", argc ? argv[0] : "program");
        return 0x1;
      }
    
      int error = 0;
      const size_t size = readuint(argv[1], &error);
      if (error) { return 0x1 + error; }
    
      uint32_t *const array = malloc(size * sizeof(uint32_t));
      if (!array) { fputs("Out of memory\n", stderr); return 0x4; }
      const uint32_t *const end = array + size;
    
      const int retval = fread16b(argv[2], array, size);
      if (retval) { free(array); return 0x10 + retval; }
    
      stretch16b32b(array, size);
      for (const uint32_t *i = array; i < end; ++i) {
        if (printf("%u\n", *i) < 0) { free(array); return 0x5; }
      }
    
      free(array);
      return 0;
    }
    

    Přeložíme to…

    clang -std=c11 -march=native -O3 -Wall -Wextra -pedantic compactread.c -o compactread
    

    …a trochu to otestujeme:

    Příklad 1 (little endian):

    $ echo -en '\x1\x0\x2\x0\x3\x0\x4\x0\x5\x0\x6\x0\x7\x0' | ./compactread 7 /dev/stdin
    1
    2
    3
    4
    5
    6
    7
    

    Příklad 2 (little endian):

    $ echo -en '\x1\x1\x1\x1' | ./compactread 2 /dev/stdin
    257
    257
    

    Příklad 3 (little endian):

    $ echo -en '\xff\xff' | ./compactread 1 /dev/stdin
    65535
    

    Příklad 4 (naprosto k hovnu, ale valgrindem taky projít musí):

    $ echo -en '' | ./compactread 0 /dev/stdin
    

    V tomto formuláři můžete formulovat svou stížnost ohledně příspěvku. Nejprve vyberte typ akce, kterou navrhujete provést s diskusí či příspěvkem. Potom do textového pole napište důvody, proč by měli admini provést vaši žádost, problém nemusí být patrný na první pohled. Odkaz na příspěvek bude přidán automaticky.

    Vaše jméno
    Váš email
    Typ požadavku
    Slovní popis
    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.