Portál AbcLinuxu, 9. května 2025 21:10
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:
ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.