abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 23:33 | Nová verze

    Google Chrome 126 byl prohlášen za stabilní. Nejnovější stabilní verze 126.0.6478.55 přináší řadu oprav a vylepšení (YouTube). Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    dnes 16:44 | Nová verze

    Byl vydán Mozilla Firefox 127.0. Přehled novinek v poznámkách k vydání, poznámkách k vydání pro firmy a na stránce věnované vývojářům. Řešeny jsou rovněž bezpečnostní chyby. Nový Firefox 127 je již k dispozici také na Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    dnes 15:11 | Nová verze

    Byla vydána (𝕏) nová verze 9.5 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    dnes 11:44 | IT novinky

    Společnost Raspberry Pi dnes vstoupila na Londýnskou burzu jako Raspberry Pi Holdings plc (investor).

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

    Do 17. června do 19:00 běží na Steamu přehlídka nadcházejících her Festival Steam Next | červen 2024 doplněná demoverzemi, přenosy a dalšími aktivitami. Demoverze lze hrát zdarma.

    Ladislav Hagara | Komentářů: 0
    včera 22:33 | IT novinky

    Apple na své vývojářské konferenci WWDC24 (Worldwide Developers Conference, keynote) představil řadu novinek: svou umělou inteligenci pojmenovanou jednoduše Apple Intelligence, iOS 18, visionOS 2, macOS Sequoia, iPadOS 18, watchOS 11, …

    Ladislav Hagara | Komentářů: 9
    včera 21:44 | Nová verze

    Vyšla nová verze XMPP (Jabber) klienta Gajim, která přidává podporu reakcí pomocí emoji (XEP-0444: Message Reactions) a citace zpráv (XEP-0461: Message Replies). Přehled dalších vylepšení je k dispozici na oficiálních stránkách.

    sonicpp | Komentářů: 1
    včera 15:00 | Nová verze

    Po po téměř roce vývoje od vydání verze 5.38 byla vydána nová stabilní verze 5.40 programovacího jazyka Perl (Wikipedie). Do vývoje se zapojilo 75 vývojářů. Změněno bylo přibližně 160 tisíc řádků v 1 500 souborech. Přehled novinek a změn v podrobném seznamu.

    Ladislav Hagara | Komentářů: 7
    včera 12:00 | Zajímavý článek

    Uroš Popović popisuje, jak si nastavit Linux na desce jako Raspberry Pi Zero, aby je šlo používat jako USB „flešku“.

    Fluttershy, yay! | Komentářů: 1
    včera 08:44 | Zajímavý software

    Andreas Kling oznámil, že jelikož už se nevěnuje nezávislému operačnímu systému SerenityOS, ale výhradně jeho webovému prohlížeči Ladybird, přičemž vyvíjí primárně na Linuxu, SerenityOS opustí a Ladybird bude nově samostatný projekt (nový web, repozitář na GitHubu).

    Fluttershy, yay! | Komentářů: 2
    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.