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í
×
    včera 17:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.

    Ladislav Hagara | Komentářů: 6
    včera 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

    Ladislav Hagara | Komentářů: 1
    včera 13:22 | Nová verze

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

    Ladislav Hagara | Komentářů: 0
    včera 12:44 | Nová verze

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

    Ladislav Hagara | Komentářů: 0
    včera 04:55 | Nová verze

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

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

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    včera 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    24.4. 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 12
    24.4. 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    24.4. 13:44 | IT novinky

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (73%)
     (9%)
     (2%)
     (16%)
    Celkem 765 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: C - float do pole uint 16b

    Beda0 avatar 31.5.2009 16:28 Beda0 | skóre: 29
    C - float do pole uint 16b
    Přečteno: 442×
    Zdravím, v C mam proměnnou typu float (32b) a pole typu unsigned short int (16b) potřebuju tu proměnnou dostat do dvou prvků toho pole a pak z těch dvou prvků pole zase zpátky do float, jak se to dělá? Radši napíšu nějakej pseudokód:
    float x;
    unsigned short int y[10];
    y[5]=//první půlka x;
    y[6]=//druhá půlka x;
    
    a pak zase spojit y[5] a y[6] do x.

    Odpovědi

    oroborus avatar 31.5.2009 16:58 oroborus | skóre: 20 | blog: Bulanci
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b

    #include <stdio.h>
    #include <math.h>
    #include <string.h>

    int main()
    {
        float x;
        unsigned short int y[10];
        int i;

        memset(y, 0, sizeof(unsigned short int)*10);

        x = M_PI;

        printf("pred x = %f\n", x);

        memcpy(y+5, &x, sizeof(x));
        //y[5]=//první půlka x;
        //y[6]=//druhá půlka x;

        x = 0.0;

        memcpy(&x, y+5, sizeof(x));
        //y[5]=//první půlka x;
        //y[6]=//druhá půlka x;

        printf("po x = %f\n", x);

        return 0;
    }

    Beda0 avatar 31.5.2009 17:01 Beda0 | skóre: 29
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Dík moc....
    31.5.2009 17:03 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Zkuste použít union - viz příklad.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    31.5.2009 20:28 deadmail
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
     y[5] = x & 0xffff;
     y[6] = x >> 16;
     x = (y[6] << 16) | y[5];
    
    1.6.2009 15:28 nikis
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b

    Elegance C-ka :)

    herne the hunter avatar 1.6.2009 17:25 herne the hunter | skóre: 10 | tor lara
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    pěkný, až na to, že to nepůjde. operandy bitových operátorů by měly být afaik celočíselný typy. nebo se pletu?
    i am herne the hunter and you are a leaf driven by the wind.
    1.6.2009 17:51 #Tom | skóre: 32 | blog: Inspirace, aneb co jsem kde vyhrabal
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Po obměnění to fungovat bude:
    y[5] = * (unsigned short int *) &x;
    y[6] = * ((unsigned short int *) &x + 1);
    ...
    * (unsigned short int *) &x = y[5];
    * ((unsigned short int *) &x + 1) = y[6];
    
    Nebo tak:
    * (float *) &y[5] = x;
    ...
    x = * (float *) &y[5];
    
    1.6.2009 18:24 Messa | skóre: 39 | blog: Messa
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b
    Fuj.
    1.6.2009 20:40 darkanry
    Rozbalit Rozbalit vše Re: C - float do pole uint 16b

    v c je taky dostupna union. Takze:

    typedef union {

      float fCislo;

      uint16 au16Cisla[2];

    } CisloVLoterii;

    ...

    CisloVLoterii *pCislo;

    ...

    pCislo = (CisloVLoterii *)&y[5];

    pCislo->fCislo = x;

    printf('%d %d\n', pCislo->au16Cisla[0], pCislo->au16Cisla[1]);

    ...

     

    Založit nové vláknoNahoru

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

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.