GNU Project Debugger aneb GDB byl vydán ve verzi 16.1. Podrobný přehled novinek v souboru NEWS.
Po 9 týdnech vývoje od vydání Linuxu 6.12 oznámil Linus Torvalds vydání Linuxu 6.13. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a Linux Kernel Newbies. Odstraněn byl souborový systém ReiserFS.
19. ledna 2038 přeteče hodnota time_t na 32bitových systémech, na vyřešení problému roku 2038 (Y2K38) tedy zbývá 13 let. Např. Debian v uplynulém roce přešel na 64bitový čas. Bernhard Wiedemann z openSUSE sdílí chyby v sestavení rozšířeného softwaru.
Byla vydána druhá opravná verze 21.2 v dubnu loňského roku vydané verze 21 multimediálního centra Kodi (dříve XBMC, Wikipedie) s kódovým označením Omega.
TikTok ve Spojených státech v sobotu večer místního času přerušil činnost. Uživatelé čínskou firmou vlastněné sociální sítě dostali zprávu, že aplikaci kvůli zákazu nelze používat. TikTok je momentálně nedostupný v obchodech s aplikacemi Google Play a App Store. Podle zákona přijatého loni a potvrzeného v pátek soudem měla platforma do dneška přerušit spojení se svou mateřskou společností ByteDance, která sídlí v Číně, nebo činnost v
… více »Wings 3D, tj. open source 3D modelovací program naprogramovaný v programovacím jazyce Erlang zaměřený na modelování pomocí subdivision a inspirovaný programy Nendo a Mirai od Izware, byl vydán v nové opravné verzi 2.4.1. Ke stažení již také ve formátu Flatpak z Flathubu.
Webový prohlížeč Dillo byl vydán ve verzi 3.2.0. Přidává podporu vzorců v SVG, obrázků ve WebP, změny velikosti stránky či možností posouvání. Nedávno oslavil 25. výročí vzniku.
Hra Mini Thief je na Steamu zdarma napořád, když aktivaci provedete do 24. ledna do 19.00 [ProtonDB].
Certifikační autorita Let's Encrypt oznámila, že bude volitelně nabízet krátkodobé certifikáty s šestidenní platností a navíc s možností vystavit je na IP adresu. Zvolit typ certifikátu bude možné v certifikačním profilu ACME.
Herní konzole Nintendo Switch 2 byla oficiálně potvrzena. Vyjde letos. Trailer na YouTube. Více ve středu 2. dubna na Nintendo Direct.
Dobry vecer,
Mam napriklad funkciu:
int sucetPrvkovPola(int *x,int k)
{
int i,s=0;
for(i=0; i<k; i++)
{
s=s+x[i];
}
return s;
}
Napriklad ked sa program pokusi scitat dva prvky s hodnotami 2 000 000 000 a napriklad 2 000 500 000 co dava spolu vacsiu hodnotu ako je rozsah integeru. Vtedy by mala funkcia skoncit s chybovym hlasenim. Neviem si s tym poradit.
Dik
Řešení dotazu:
s
ako long a tú testovať na INT_MAX a INT_MIN.
long long int
a kompilovať to s voľbou -std=c99
.
int a,b ... if ((a > 0) && (b > 0) && (INT_MAX - a > b)) printf("a+b pretece"); if ((a < 0) && (b < 0) && (a < INT_MIN - b)) printf("a+b podtece");Varianta 2:
int a,b ... int c = a+b; if ((a > 0) && (c < b)) printf("a+b preteklo"); if ((a < 0) && (c > b)) printf("a+b podteklo");
A jak byste pánové chtěli detekovat přetečení long longu? "To nejde"?No predsa long long longom... :P
Catching Integer Overflows in C
Here is a complete set of three functions for ``careful'' addition, subtraction, and multiplication.:
#include <stdio.h> #include <limits.h> int chkadd(int a, int b) { if(b < 0) return chksub(a, -b); if(INT_MAX - b < a) { fputs("int overflow\n", stderr); return INT_MAX; } return a + b; } int chksub(int a, int b) { if(b < 0) return chkadd(a, -b); if(INT_MIN + b > a) { fputs("int underflow\n", stderr); return INT_MIN; } return a - b; } int chkmul(int a, int b) { int sign = 1; if(a == 0 || b == 0) return 0; if(a < 0) { a = -a; sign = -sign; } if(b < 0) { b = -b; sign = -sign; } if(INT_MAX / b < a) { fputs("int overflow\n", stderr); return (sign > 0) ? INT_MAX : INT_MIN; } return sign * a * b; }
epic fail!return chksub(a, -b);
chkadd()
se volá
chksub(a, -b)
pouze, když je
b
záporné číslo.
Tedy v
chksub()
se nemůže zavolat
chkadd(a, -b)
,
protože ze záporného
b
se udělalo kladné, tedy žádná nekonečná rekurze se nekoná.
Pokud si někdo myslí opak, uveďte konkrétní příklad, možná se na to jen nedívám z dostatečného odstupu a stále mi něco uniká.
main() {int i = -2147483648; printf ("%x %x %s\n", i, (-i), (i == -i)?"pooh":""); }To je svinské číslo, které je záporné, i když se z něj veme absolutní hodnota :) Holt matematika a numerická matematika jsou dvě různé věci, s floating point čísly je to ještě horší.
Ach ta nepozornost, hlavně, že mají před začátkem kódu poznámku:
(Note: these functions all share one bug: they may fail if invoked on the largest negative integer, INT_MIN.)
Za druhé - "detekci přetečení uděláme tak, že použijeme číslo s větším rozsahem" - wtf? A jak byste pánové chtěli detekovat přetečení long longu? "To nejde"?V zadání se sčítaly tuším dva 32bit integery, mám takový dojem, že při sečtení se 64bit limit nikdy nepřekročí :-P.
Tiskni Sdílej: