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 22:00 | Komunita

Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil (podcast) detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 64 tisíc vývojářů. Jejich nejmilovanější platformou je linuxový desktop. Ten je také druhou nejpoužívanější platformou vývojářů.

Ladislav Hagara | Komentářů: 0
24.3. 11:55 | Komunita

Vývojový tým OpenSSL ve spolupráci s iniciativou Core Infrastructure konsorcia Linux Foundation spustil proces přelicencování této kryptografické knihovny ze současné licence na licenci Apache Licence v 2.0 (ASLv2). Nová licence usnadní začleňování OpenSSL do dalších svobodných a open source projektů. Všichni dosavadní vývojáři OpenSSL (Authors) obdrží v následujících dnech email s prosbou o souhlas se změnou licence.

Ladislav Hagara | Komentářů: 8
24.3. 01:11 | Komunita

Před třemi týdny Mozilla.cz představila projekt Photon, jehož cílem je návrh a implementace nového vzhledu Firefoxu. Včera zveřejnila první náhled vzhledu Photon. Práce na projektu Photon jsou rozděleny do pěti týmů, které celkem čítají 19 lidí. Zaměřují se na zlepšení prvního spuštění Firefoxu a zaujetí nových uživatelů, celkovou úpravu vzhledu, zlepšení animací, zrychlení odezvy uživatelského rozhraní a také upravení nabídek. Vývoj lze sledovat v Bugzille.

Ladislav Hagara | Komentářů: 38
23.3. 20:00 | Komunita

OneDrive pro firmy je již ve webových prohlížečích na Linuxu stejně rychlý jako na Windows. Microsoft opravil chybu z listopadu loňského roku. OneDrive pro firmy běžel na Linuxu mnohem pomaleji než na Windows. V popisu chyby bylo uvedeno, že stačilo v prohlížeči na Linuxu nastavit v user-agentu Windows a vše se zrychlilo. Odpovědí Microsoftu bylo (Internet Archive: Wayback Machine), že Linux není podporován. Po bouřlivých diskusích na redditu i Hacker News byla chyba nalezena a opravena.

Ladislav Hagara | Komentářů: 6
23.3. 19:00 | Zajímavý projekt

Byla vyhlášena soutěž Hackaday Prize 2017. Soutěž je určena vývojářům open source hardwaru. Pro výherce je připraveno celkově 250 tisíc dolarů. Každý ze 120 finalistů získá tisíc dolarů. Nejlepší pak navíc 50, 30, 20, 15, 10 a 5 tisíc dolarů. Jedná se již o čtvrtý ročník soutěže. V roce 2014 zvítězil projekt globální sítě open source pozemních satelitních stanic SatNOGS. V roce 2015 zvítězil open source systém pro řízení elektrických invalidních vozíků pohybem očí Eyedriveomatic. V roce 2016 zvítězil modulární robot Dtto.

Ladislav Hagara | Komentářů: 0
23.3. 15:00 | Bezpečnostní upozornění

Byla vydána Samba ve verzích 4.6.1, 4.5.7 a 4.4.12. Řešen je bezpečnostní problém CVE-2017-2619. Pomocí symbolických odkazů a souběhu (symlink race) lze "teoreticky" získat přístup k souborům, které nejsou sdíleny. Linuxové distribuce jsou postupně aktualizovány (Debian).

Ladislav Hagara | Komentářů: 0
23.3. 07:43 | Nová verze

Na Steamu se objevil port hry Arma: Cold War Assault (Operation Flashpoint) pro Mac a Linux. … více »

creon | Komentářů: 30
23.3. 05:55 | Nová verze

Po 18 měsících od vydání verze 8.0 byla vydána verze 9.0 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab. Představení nových vlastností v příspěvku na blogu a na YouTube.

Ladislav Hagara | Komentářů: 0
23.3. 03:33 | Komunita

Platnost posledního patentu souvisejícího s Dolby Digital (AC-3) vypršela. Po MP3 se tak do Fedory oficiálně dostane také kodek AC-3.

Ladislav Hagara | Komentářů: 5
23.3. 00:44 | Komunita

Feral Interactive, společnost zabývající se vydáváním počítačových her pro operační systémy macOS a Linux, nabízí své hry na Steamu vývojářům open source 3D grafické knihovny Mesa zdarma. Podmínkou je minimálně 25 commitů za posledních 5 let. Stejnou nabídku dostali vývojáři knihovny Mesa v roce 2015 od Valve. O rok dříve dostali od Valve tuto nabídku vývojáři Debianu a Ubuntu.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (14%)
 (2%)
 (72%)
 (3%)
 (10%)
Celkem 934 hlasů
 Komentářů: 72, poslední 1.3. 11:16
    Rozcestník

    Dotaz: C: Signed proměnná - maximální hodnota

    20.1.2011 00:38 Jiří J. | skóre: 34 | blog: Poutník | Brno
    C: Signed proměnná - maximální hodnota
    Přečteno: 773×

    Zdravím,
    mám tu zajímavý problém - rád bych zjistil maximální hodnotu signed proměnné za běhu programu, abych ji pak mohl porovnat s matematickými operacemi nad jinými proměnnými a zabránit přetečení. Jedná se konkrétně o off_t, což je offset typ, který používá např. lseek(). Jen pro úplnost - píši čistě POSIX a multiplatformní program.

    Prvním problémem je, že neexistuje nic jako OFF_T_MAX. Zkoušel jsem i fígle jako (~((off_t)0)>>1), které pochopitelně nefungují, protože v C se provádí nad signed proměnnými aritmetický right shift, takže se MSB bit zkopíruje, tím pádem se celková hodnota vůbec nemění.

    Druhým problémem je, že předchozí výraz nemohu prostě před shiftem přetypovat na uint64_t či unsigned long long, protože na některých architekturách může pořád být off_t jen 32bitová proměnná.

    Tady jsem se vlastně chtěl zeptat - pokud přetypuji 32bit proměnnou na zásobníku na 64bit unsigned integerový datový typ (fuj, ta čeština) a provedu shift, přibere s sebou shift i předchozích 32bitů na zásobníku (způsobujíc data corruption), nebo se s tím C vypořádá a provede shift jen v rámci 32bit proměnné? Něco jako

    int i = ~(int)0;
    ... ((unsigned long long)i>>1) ...
    V mém testovacím programu se provedl shift jen v rámci jedné 32bit proměnné, ale to je dost možná kvůli nepoužití zásobníku v rámci optimalizací GCC (ověřeno objdumpem).

    V zásadě tedy potřebuji nějak dostat nulu do MSB nějaké signed proměnné, u které neznám předem velikost. Jako poslední řešení mám v rukávu něco jako (pow(2,sizeof(off_t)*8)/2)-1 (přes double) nebo inline assembly, ale raději bych použil cokoli elegantnějšího.

    Díky za jakoukoli pomoc.

    Víra je firma si myslela, že něco je pravdivé. LMAO -- “zlehčovat mého osla”

    Řešení dotazu:


    Odpovědi

    Bilbo avatar 20.1.2011 01:49 Bilbo | skóre: 29
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    sizeof(off_t)*8 je velikost v bitech, takže možná by pak šlo napsat:

    const int OFF_T_MAX = 1<<(sizeof(off_t)*8-1)-1;

    Tedy dostat na první bit 1, na zbylé 0 (čímž dostanu minimální možnou hodnotu pokud jde o signed typ) a pak odečíst 1 (tím to přeteče a mám maximum)

    Big brother is not watching you anymore. Big Brother is telling you how to live...
    Bilbo avatar 20.1.2011 01:58 Bilbo | skóre: 29
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Sorry, ten typ musí být taky off_t .... a to i ta jednička, jinak to vezme jako int.

    Tohle už funguje (odzkoušeno :):

    const off_t OFF_T_MAX = ((off_t)1)<<(sizeof(off_t)*8-1)-1;
    Big brother is not watching you anymore. Big Brother is telling you how to live...
    20.1.2011 02:24 Jiří J. | skóre: 34 | blog: Poutník | Brno
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota

    Díky za nápad, že mě to netrklo dřív :-).

    Nicméně myslím, že tam vypadla jedna závorka, to -1 se odečítá od pravé strany shift operátoru, stačilo to poupravit tak, ať se odečítá od výsledku shiftu:

    const off_t OFF_T_MAX = (((off_t)1)<<(sizeof(off_t)*8-1))-1;
    a už to konečně opravdu funguje :-).

    Víra je firma si myslela, že něco je pravdivé. LMAO -- “zlehčovat mého osla”
    Bilbo avatar 20.1.2011 02:42 Bilbo | skóre: 29
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Aha, zapomněl jsem, že << má menší prioritu než + a -.
    Big brother is not watching you anymore. Big Brother is telling you how to live...
    20.1.2011 16:51 finn | skóre: 42 | blog: finnlandia | 49° 44´/13° 22´
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    sizeof(off_t)*8 je velikost v bitech
    Není. Tahle konstrukce vychází z mylného předpokladu, že bajt má vždy osm bitů. Pokud chci zjisti počet bitů datového typu, je třeba použít konstantu CHAR_BIT:
    #include <limits.h>
    ...
    int bl = sizeof(off_t) * CHAR_BIT;
    Užívej dne – možná je tvůj poslední.
    Bilbo avatar 20.1.2011 22:40 Bilbo | skóre: 29
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    To je pravda, ale většina počítačů, kde tohle neplatí (jsou i takové, kde int má třeba 36 nebo 37 bitů (jeden je vyhrazen na znaménko) a některé z nich mají byte tuším 8bit, některé 9bit) jsou natolik staré, případně obskurní, že tam možná ani to C nepojede. POSIX např. má CHAR_BIT==8 jako jeden z předpokladů.
    Big brother is not watching you anymore. Big Brother is telling you how to live...
    21.1.2011 07:29 finn | skóre: 42 | blog: finnlandia | 49° 44´/13° 22´
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Tak třeba klik. CHAR_BIT == 16. Navíc, používat v kódu natvrdo čísla není moc čisté, daleko lepší je použít rozumně pojmenovanou a okomentovanou nebo standardně definovanou konstantu (v tomhle případě CHAR_BIT).
    Užívej dne – možná je tvůj poslední.
    20.1.2011 09:26 chochi | skóre: 29 | Praha
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Alternativne se da pouzit pristup glibc:
    
    /*
     * Type helpers (from glibc)
     */
    
    /* True if the arithmetic type T is signed.  */
    #define TYPE_SIGNED(t) (! ((t) 0 < (t) -1))
    
    #define TYPE_SIGNED_MAGNITUDE(t) ((t) ~ (t) 0 < (t) -1)
    
    /* The maximum and minimum values for the integer type T.  These
       macros have undefined behavior if T is signed and has padding bits.
       If this is a problem for you, please let us know how to fix it for
       your host.  */
    #define TYPE_MINIMUM(t) \
      ((t) (! TYPE_SIGNED (t) \
    	? (t) 0 \
    	: TYPE_SIGNED_MAGNITUDE (t) \
    	? ~ (t) 0 \
    	: ~ (t) 0 << (sizeof (t) * CHAR_BIT - 1)))
    #define TYPE_MAXIMUM(t) \
      ((t) (! TYPE_SIGNED (t) \
    	? (t) -1 \
    	: ~ (~ (t) 0 << (sizeof (t) * CHAR_BIT - 1))))
    
    #ifndef TIME_T_MIN
    # define TIME_T_MIN TYPE_MINIMUM (time_t)
    #endif
    #ifndef TIME_T_MAX
    # define TIME_T_MAX TYPE_MAXIMUM (time_t)
    #endif
    
    20.1.2011 11:54 l4m4
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    rád bych zjistil maximální hodnotu signed proměnné za běhu programu
    Proč za běhu? Ona se může od kompilace změnit?
    20.1.2011 17:02 Jirka P
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Tady jsem se vlastně chtěl zeptat - pokud přetypuji 32bit proměnnou na zásobníku na 64bit unsigned integerový datový typ (fuj, ta čeština) a provedu shift, přibere s sebou shift i předchozích 32bitů na zásobníku (způsobujíc data corruption), nebo se s tím C vypořádá a provede shift jen v rámci 32bit proměnné?
    Na tyhle úvahy o bitech na zásobníku zapomeňte, jsou nesmyslné. V zásadě při přetypování celých čísel platí:
    • pokud lze hodnotu zdroje vyjádřit cílovým typem, hodnota se zachová
    • pokud je cílový typ unsigned, hodnota se zachová modulo rozsah cílového typu
    • jinak je výsledek nedefinovaný
    Takže ve vašem případě se žádný "bity ze zásobníku" neberou.
    20.1.2011 17:29 Sten
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Unsigned verzí off_t je size_t. Maximální hodnotu tedy zjistíte pomocí: (off_t)((size_t)(~((off_t)0))>>1).

    Maximální velikost se za běhu nemůže změnit, je stejná jako v případě kompilace.
    Jardík avatar 8.2.2011 16:39 Jardík | skóre: 40 | blog: jarda_bloguje
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Unsigned verzí off_t je size_t.
    Větší kravinu jsem nikdy neslyšel ...
    Věřím v jednoho Boha.
    rADOn avatar 8.2.2011 17:43 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: C: Signed proměnná - maximální hodnota
    Větší kravinu jsem nikdy neslyšel ...
    Nech si někdy ukázat televizi. To budeš koukat jak se ti rozšíří obzory.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco

    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.