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 04:00 | Bezpečnostní upozornění

    Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.

    Ladislav Hagara | Komentářů: 2
    dnes 03:33 | Zajímavý software

    Nightingale je open-source karaoke aplikace, která z jakékoliv písničky lokálního alba (včetně videí) dokáže oddělit vokály, získat text a vše přehrát se synchronizací na úrovni jednotlivých slov a hodnocením intonace. Pro separaci vokálů využívá UVR Karaoke model s Demucs od Mety, texty písní stahuje z lrclib.net (LRCLIB), případně extrahuje pomocí whisperX, který rovněž využívá k načasování slov. V případě audiosouborů aplikace na

    … více »
    NUKE GAZA! 🎆 | Komentářů: 0
    včera 18:22 | Nová verze

    Po půl roce vývoje od vydání verze 49 bylo vydáno GNOME 50 s kódovým názvem Tokyo (Mastodon). Podrobný přehled novinek i s náhledy v poznámkách k vydání a v novinkách pro vývojáře.

    Ladislav Hagara | Komentářů: 6
    včera 17:22 | Nová verze

    Článek na stránkách Fedora Magazinu informuje o vydání Fedora Asahi Remixu 43, tj. linuxové distribuce pro Apple Silicon vycházející z Fedora Linuxu 43.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | Pozvánky

    Byl zveřejněn program konference Installfest 2026. Konference proběhne o víkendu 28. a 29. března v Praze na Karlově náměstí 13. Vstup zdarma.

    Ladislav Hagara | Komentářů: 3
    včera 03:55 | Nová verze

    Byla vydána Java 26 / JDK 26. Nových vlastností (JEP - JDK Enhancement Proposal) je 10. Odstraněno bylo Applet API.

    Ladislav Hagara | Komentářů: 10
    17.3. 23:55 | Nová verze

    Byla vydána nová verze 260 správce systému a služeb systemd (Wikipedie, GitHub). Odstraněna byla podpora skriptů System V. Aktualizovány byly závislosti. Minimální verze Linuxu z 5.4 na 5.10, OpenSSL z 1.1.0 na 3.0.0, Pythonu z 3.7.0 na 3.9.0…

    Ladislav Hagara | Komentářů: 22
    17.3. 18:11 | Nová verze

    Byla vydána nová verze 5.1 svobodného 3D softwaru Blender. Přehled novinek i s náhledy a videi v poznámkách k vydání. Videopředstavení na YouTube.

    Ladislav Hagara | Komentářů: 0
    17.3. 04:55 | Nová verze

    Bylo oznámeno vydání nové verze 8.1 "Hoare" kolekce svobodného softwaru umožňujícího nahrávání, konverzi a streamovaní digitálního zvuku a obrazu FFmpeg (Wikipedie). Doprovodný příspěvek na blogu Khronosu rozebírá kódování a dekódování videa pomocí Vulkan Compute Shaders v FFmpeg.

    Ladislav Hagara | Komentářů: 12
    17.3. 04:33 | Zajímavý projekt

    Byl představen open-source a open-hardware prototyp nízkonákladového raketometu kategorie MANPADS, který byl sestaven z běžně dostupné elektroniky a komponent vytištěných na 3D tiskárně. Raketa využívá skládací stabilizační křidélka a canardovou stabilizaci aktivně řízenou palubním letovým počítačem ESP32, vybaveným inerciální měřicí jednotkou MPU6050 (gyroskop a akcelerometr). Přenosné odpalovací zařízení obsahuje GPS,

    … více »
    NUKE GAZA! 🎆 | Komentářů: 46
    Které desktopové prostředí na Linuxu používáte?
     (16%)
     (7%)
     (1%)
     (11%)
     (29%)
     (2%)
     (5%)
     (1%)
     (13%)
     (24%)
    Celkem 1109 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    Dotaz: cast int na double

    20.1.2017 20:11 Pavel
    cast int na double
    Přečteno: 542×
    Dneska jsem v logu jednoho programu viděl změnu:
      int giveMeAnInt();
      double giveMeADouble();
      
      double a = giveMeADouble();
    - double b = giveMeAnInt();
    - double c = a / b;
    + int b = giveMeAnInt();
    + double c = a / static_cast<double>(b);
    
    Může mi někdo vysvětlit přínos takové změny? Za sebe musím říct, že se mi změna nezdá a na jakýchsi (neznámých) platformách, kde double nemůže reprezentovat všechny hodnoty intu, nový kód pravděpodobněji skryje problém / potlačí varování kompilátoru o možné ztrátě přesnosti.

    Odpovědi

    20.1.2017 21:04 Sten
    Rozbalit Rozbalit vše Re: cast int na double
    Pokud se b nikde dál nepoužívá, tak je oboje totožné. Pokud by double nedokázal reprezentovat přesnou hodnotu intu, tak se použije nejbližší hodnota, a to i v prvním případě velmi pravděpodobně bez varování, protože to není constexpr a u runtime ztráty přesnosti kompilátor nevaruje (nemá jak).
    20.1.2017 22:13 Pavel
    Rozbalit Rozbalit vše Re: cast int na double
    Pokud si vzpomínám, tak při konverzi uint64_t na double mi kompilátor kdysi hlásil "Possible loss of precision".
    20.1.2017 22:20 Pavel
    Rozbalit Rozbalit vše Re: cast int na double
    Už jsem to našel
    #include <iostream>
    
    int main()
    {
        long a;
        long b;
        
        std::cin >> a >> b;
        
        double ad = a;
        double bd = static_cast<double>(b);
        std::cout << ad << bd;
    }
    
    Zkompiluju g++ -Wconversion -o a a.cpp. Dostanu
    a.cpp: In function ‘int main()’:
    a.cpp:10:17: warning: conversion to ‘double’ from ‘long int’ may alter its value [-Wconversion]
         double ad = a;
                     ^
    
    Static cast mi tedy potlačí varování na platformě, kde nelze provést konverzi pro všechny hodnoty zdrojového typu.
    25.1.2017 01:02 Sten
    Rozbalit Rozbalit vše Re: cast int na double
    Hmm, zajímavé. Je pravda, že ISO C++ definuje, jak se to má převést, ale už nedefinuje, jestli je to úmyslné chování (a tedy není nutné varovat, jako třeba převod int na bool) nebo jen definovaný vedlejší efekt (a tedy je vhodné varovat, jako u převodu int na char).
    24.1.2017 21:48 Vladimír Čunát | skóre: 19
    Rozbalit Rozbalit vše Re: cast int na double
    int je standardně 32-bit i na 64-bit (unix-like) platformách a myslím že 32-bit jde vždy v doublu reprezentovat bezztrátově (mantissa má ~50 bitů).
    25.1.2017 01:32 Sten
    Rozbalit Rozbalit vše Re: cast int na double
    Na to není dobré spoléhat. Třeba knihovny Intel MKL používají ILP64, takže pokud kompilujete vůči nim (rozšíření FORTRANu), budete mít 64bitové inty. Na druhou stranu ISO C++ povoluje, aby double byl stejně přesný jako float, takže u soft float architektur (třeba ARMv5) může mít váš program klidně doubly s 24bitovou mantisou.

    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.