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

    VKD3D-Proton byl vydán ve verzi 3.0. Jedná se fork knihovny vkd3d z projektu Wine pro Proton. Knihovna slouží pro překlad volání Direct3D 12 na Vulkan. V přehledu novinek je vypíchnuta podpora AMD FSR 4 (AMD FidelityFX Super Resolution 4).

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

    Poštovní klient Thunderbird byl vydán v nové verzi 145.0. Podporuje DNS přes HTTPS nebo Microsoft Exchange skrze Exchange Web Services. Ukončena byla podpora 32bitového Thunderbirdu pro Linux.

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

    U příležitosti státního svátku 17. listopadu probíhá na Steamu i GOG.com již šestý ročník Czech & Slovak Games Week aneb týdenní oslava a také slevová akce českých a slovenských počítačových her.

    Ladislav Hagara | Komentářů: 0
    16.11. 19:33 | Nová verze

    Byla vydána nová verze 9.19 z Debianu vycházející linuxové distribuce DietPi pro (nejenom) jednodeskové počítače. Přehled novinek v poznámkách k vydání. Vypíchnout lze například nový balíček BirdNET-Go, tj. AI řešení pro nepřetržité monitorování a identifikaci ptáků.

    Ladislav Hagara | Komentářů: 0
    16.11. 02:22 | Nová verze

    Byla vydána nová verze 3.38 frameworku Flutter (Wikipedie) pro vývoj mobilních, webových i desktopových aplikací a nová verze 3.10 souvisejícího programovacího jazyka Dart (Wikipedie).

    Ladislav Hagara | Komentářů: 0
    16.11. 01:33 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 28 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    15.11. 16:11 | Nová verze

    Byl vydán Debian 13.2, tj. druhá opravná verze Debianu 13 s kódovým názvem Trixie. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    15.11. 12:11 | IT novinky

    Google představil platformu Code Wiki pro rychlejší porozumění existujícímu kódu. Code Wiki pomocí AI Gemini udržuje průběžně aktualizovanou strukturovanou wiki pro softwarové repozitáře. Zatím jenom pro veřejné. V plánu je rozšíření Gemini CLI také pro soukromé a interní repozitáře.

    Ladislav Hagara | Komentářů: 5
    14.11. 14:22 | Bezpečnostní upozornění

    V přihlašovací obrazovce LightDM KDE (lightdm-kde-greeter) byla nalezena a již opravena eskalace práv (CVE-2025-62876). Detaily v příspěvku na blogu SUSE Security.

    Ladislav Hagara | Komentářů: 5
    14.11. 13:22 | Nová verze

    Byla vydána nová verze 7.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Tor Browser byl povýšen na verzi 15.0.1. Další novinky v příslušném seznamu.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (46%)
     (18%)
     (18%)
     (23%)
     (15%)
     (23%)
     (16%)
     (16%)
    Celkem 360 hlasů
     Komentářů: 16, poslední 12.11. 18:21
    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: 499×
    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.