How to detect integer overflow in C [duplicate] Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live!How do I detect unsigned integer multiply overflow?Detecting signed overflow in C/C++How do I check if A+B exceed long long? (both A and B is long long)Test for overflow in integer additionHow do you set, clear, and toggle a single bit?How do I detect unsigned integer multiply overflow?Improve INSERT-per-second performance of SQLite?Catch and compute overflow during multiplication of two large integersWhen to address integer overflow in CDetecting signed overflow in C/C++How to find (all) integer overflows in a C program?Speed comparison with Project Euler: C vs Python vs Erlang vs HaskellHow to check if overflow occured?automatic overflow detection in C++?

How can I prevent/balance waiting and turtling as a response to cooldown mechanics

If Windows 7 doesn't support WSL, then what is "Subsystem for UNIX-based Applications"?

A term for a woman complaining about things/begging in a cute/childish way

Is multiple magic items in one inherently imbalanced?

Co-worker has annoying ringtone

Project Euler #1 in C++

What is a more techy Technical Writer job title that isn't cutesy or confusing?

How to write capital alpha?

Question about this thing for timpani

How many time has Arya actually used Needle?

Random body shuffle every night—can we still function?

Most effective melee weapons for arboreal combat? (pre-gunpowder technology)

Why not send Voyager 3 and 4 following up the paths taken by Voyager 1 and 2 to re-transmit signals of later as they fly away from Earth?

Is there hard evidence that the grant peer review system performs significantly better than random?

What does 丫 mean? 丫是什么意思?

Why is std::move not [[nodiscard]] in C++20?

As a dual citizen, my US passport will expire one day after traveling to the US. Will this work?

What is the difference between a "ranged attack" and a "ranged weapon attack"?

Is there any word for a place full of confusion?

I got rid of Mac OSX and replaced it with linux but now I can't change it back to OSX or windows

What does Turing mean by this statement?

One-one communication

Why datecode is SO IMPORTANT to chip manufacturers?

Weaponising the Grasp-at-a-Distance spell



How to detect integer overflow in C [duplicate]



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)
Data science time! April 2019 and salary with experience
The Ask Question Wizard is Live!How do I detect unsigned integer multiply overflow?Detecting signed overflow in C/C++How do I check if A+B exceed long long? (both A and B is long long)Test for overflow in integer additionHow do you set, clear, and toggle a single bit?How do I detect unsigned integer multiply overflow?Improve INSERT-per-second performance of SQLite?Catch and compute overflow during multiplication of two large integersWhen to address integer overflow in CDetecting signed overflow in C/C++How to find (all) integer overflows in a C program?Speed comparison with Project Euler: C vs Python vs Erlang vs HaskellHow to check if overflow occured?automatic overflow detection in C++?



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








17
















This question already has an answer here:



  • Detecting signed overflow in C/C++

    12 answers



  • How do I detect unsigned integer multiply overflow?

    31 answers



We know CPython promotes integers to long integers (which allow arbitrary-precision arithmetic) silently when the number gets bigger.



How can we detect overflow of int and long long in pure C?










share|improve this question















marked as duplicate by sleske, ead, phuclv, Cody Gray Apr 2 at 16:38


This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.













  • 3





    It's very tricky since you just can't add two numbers and check if the value is above some threshold (because signed integer arithmetic overflow and such). A simple solution might be to check if x (the value you want to check) is above a specific threshold, or if adding one goes above a threshold. If it does and the other number you want to add is larger than one, then you have an overflow situation.

    – Some programmer dude
    Apr 2 at 7:11







  • 1





    Nitpick, but, it was CPython 2.7 that did this. CPython 3 doesn't "promote" anything, even internally there is just one type.

    – Antti Haapala
    Apr 2 at 12:49






  • 1





    there are a lot of duplicates depending on what you want to do with the values (add/sub/mul/div/...?) How to check if A+B exceed long long? (both A and B is long long), Detecting signed overflow in C/C++, Test for overflow in integer addition

    – phuclv
    Apr 2 at 14:00












  • and add 1 more codereview.stackexchange.com/questions/37177/…

    – NoChance
    Apr 2 at 14:36

















17
















This question already has an answer here:



  • Detecting signed overflow in C/C++

    12 answers



  • How do I detect unsigned integer multiply overflow?

    31 answers



We know CPython promotes integers to long integers (which allow arbitrary-precision arithmetic) silently when the number gets bigger.



How can we detect overflow of int and long long in pure C?










share|improve this question















marked as duplicate by sleske, ead, phuclv, Cody Gray Apr 2 at 16:38


This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.













  • 3





    It's very tricky since you just can't add two numbers and check if the value is above some threshold (because signed integer arithmetic overflow and such). A simple solution might be to check if x (the value you want to check) is above a specific threshold, or if adding one goes above a threshold. If it does and the other number you want to add is larger than one, then you have an overflow situation.

    – Some programmer dude
    Apr 2 at 7:11







  • 1





    Nitpick, but, it was CPython 2.7 that did this. CPython 3 doesn't "promote" anything, even internally there is just one type.

    – Antti Haapala
    Apr 2 at 12:49






  • 1





    there are a lot of duplicates depending on what you want to do with the values (add/sub/mul/div/...?) How to check if A+B exceed long long? (both A and B is long long), Detecting signed overflow in C/C++, Test for overflow in integer addition

    – phuclv
    Apr 2 at 14:00












  • and add 1 more codereview.stackexchange.com/questions/37177/…

    – NoChance
    Apr 2 at 14:36













17












17








17


1







This question already has an answer here:



  • Detecting signed overflow in C/C++

    12 answers



  • How do I detect unsigned integer multiply overflow?

    31 answers



We know CPython promotes integers to long integers (which allow arbitrary-precision arithmetic) silently when the number gets bigger.



How can we detect overflow of int and long long in pure C?










share|improve this question

















This question already has an answer here:



  • Detecting signed overflow in C/C++

    12 answers



  • How do I detect unsigned integer multiply overflow?

    31 answers



We know CPython promotes integers to long integers (which allow arbitrary-precision arithmetic) silently when the number gets bigger.



How can we detect overflow of int and long long in pure C?





This question already has an answer here:



  • Detecting signed overflow in C/C++

    12 answers



  • How do I detect unsigned integer multiply overflow?

    31 answers







c overflow






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Apr 2 at 22:45









Peter Mortensen

14k1987114




14k1987114










asked Apr 2 at 7:07









DeanDean

11215




11215




marked as duplicate by sleske, ead, phuclv, Cody Gray Apr 2 at 16:38


This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.









marked as duplicate by sleske, ead, phuclv, Cody Gray Apr 2 at 16:38


This question has been asked before and already has an answer. If those answers do not fully address your question, please ask a new question.









  • 3





    It's very tricky since you just can't add two numbers and check if the value is above some threshold (because signed integer arithmetic overflow and such). A simple solution might be to check if x (the value you want to check) is above a specific threshold, or if adding one goes above a threshold. If it does and the other number you want to add is larger than one, then you have an overflow situation.

    – Some programmer dude
    Apr 2 at 7:11







  • 1





    Nitpick, but, it was CPython 2.7 that did this. CPython 3 doesn't "promote" anything, even internally there is just one type.

    – Antti Haapala
    Apr 2 at 12:49






  • 1





    there are a lot of duplicates depending on what you want to do with the values (add/sub/mul/div/...?) How to check if A+B exceed long long? (both A and B is long long), Detecting signed overflow in C/C++, Test for overflow in integer addition

    – phuclv
    Apr 2 at 14:00












  • and add 1 more codereview.stackexchange.com/questions/37177/…

    – NoChance
    Apr 2 at 14:36












  • 3





    It's very tricky since you just can't add two numbers and check if the value is above some threshold (because signed integer arithmetic overflow and such). A simple solution might be to check if x (the value you want to check) is above a specific threshold, or if adding one goes above a threshold. If it does and the other number you want to add is larger than one, then you have an overflow situation.

    – Some programmer dude
    Apr 2 at 7:11







  • 1





    Nitpick, but, it was CPython 2.7 that did this. CPython 3 doesn't "promote" anything, even internally there is just one type.

    – Antti Haapala
    Apr 2 at 12:49






  • 1





    there are a lot of duplicates depending on what you want to do with the values (add/sub/mul/div/...?) How to check if A+B exceed long long? (both A and B is long long), Detecting signed overflow in C/C++, Test for overflow in integer addition

    – phuclv
    Apr 2 at 14:00












  • and add 1 more codereview.stackexchange.com/questions/37177/…

    – NoChance
    Apr 2 at 14:36







3




3





It's very tricky since you just can't add two numbers and check if the value is above some threshold (because signed integer arithmetic overflow and such). A simple solution might be to check if x (the value you want to check) is above a specific threshold, or if adding one goes above a threshold. If it does and the other number you want to add is larger than one, then you have an overflow situation.

– Some programmer dude
Apr 2 at 7:11






It's very tricky since you just can't add two numbers and check if the value is above some threshold (because signed integer arithmetic overflow and such). A simple solution might be to check if x (the value you want to check) is above a specific threshold, or if adding one goes above a threshold. If it does and the other number you want to add is larger than one, then you have an overflow situation.

– Some programmer dude
Apr 2 at 7:11





1




1





Nitpick, but, it was CPython 2.7 that did this. CPython 3 doesn't "promote" anything, even internally there is just one type.

– Antti Haapala
Apr 2 at 12:49





Nitpick, but, it was CPython 2.7 that did this. CPython 3 doesn't "promote" anything, even internally there is just one type.

– Antti Haapala
Apr 2 at 12:49




1




1





there are a lot of duplicates depending on what you want to do with the values (add/sub/mul/div/...?) How to check if A+B exceed long long? (both A and B is long long), Detecting signed overflow in C/C++, Test for overflow in integer addition

– phuclv
Apr 2 at 14:00






there are a lot of duplicates depending on what you want to do with the values (add/sub/mul/div/...?) How to check if A+B exceed long long? (both A and B is long long), Detecting signed overflow in C/C++, Test for overflow in integer addition

– phuclv
Apr 2 at 14:00














and add 1 more codereview.stackexchange.com/questions/37177/…

– NoChance
Apr 2 at 14:36





and add 1 more codereview.stackexchange.com/questions/37177/…

– NoChance
Apr 2 at 14:36












3 Answers
3






active

oldest

votes


















18














You can predict signed int overflow but attempting to detect it after the summation is too late. You have to test for possible overflow before you do a signed addition.



It's not possible to avoid undefined behaviour by testing for it after the summation. If the addition overflows then there is already undefined behaviour.



If it were me, I'd do something like this:



#include <limits.h>

int safe_add(int a, int b)

if (a >= 0)
if (b > (INT_MAX - a))
/* handle overflow */

else
if (b < (INT_MIN - a))
/* handle underflow */


return a + b;



Refer this paper for more information. You can also find why unsigned integer overflow is not undefined behaviour and what could be portability issues in the same paper.



EDIT:



GCC and other compilers have some provisions to detect the overflow. For example, GCC has following built-in functions allow performing simple arithmetic operations together with checking whether the operations overflowed.



bool __builtin_add_overflow (type1 a, type2 b, type3 *res)
bool __builtin_sadd_overflow (int a, int b, int *res)
bool __builtin_saddl_overflow (long int a, long int b, long int *res)
bool __builtin_saddll_overflow (long long int a, long long int b, long long int *res)
bool __builtin_uadd_overflow (unsigned int a, unsigned int b, unsigned int *res)
bool __builtin_uaddl_overflow (unsigned long int a, unsigned long int b, unsigned long int *res)
bool __builtin_uaddll_overflow (unsigned long long int a, unsigned long long int b, unsigned long long int *res)


Visit this link.



EDIT:



Regarding the question asked by someone




I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..




The answer depends upon the implementation of the compiler. Most C implementations (compilers) just used whatever overflow behaviour was easiest to implement with the integer representation it used.



In practice, the representations for signed values may differ (according to the implementation): one's complement, two's complement, sign-magnitude. For an unsigned type there is no reason for the standard to allow variation because there is only one obvious binary representation (the standard only allows binary representation).






share|improve this answer

























  • Why extra parentheses? Also you could save one test on average with if (a >= 0) test overflow else test underflow return a + b;

    – chqrlie
    Apr 2 at 7:28












  • @chqrlie that is not sufficient because there is no possibility of overflow when a == 0.

    – Antti Haapala
    Apr 2 at 7:30











  • It is not necessary to test overflow if a == 0 but testing a just once saves one comparison if a < 0, which is half the cases.

    – chqrlie
    Apr 2 at 7:32






  • 8





    Also, both are technically called overflow. Underflow means that the value is too small in magnitude to be representable in a floating point variable.

    – Antti Haapala
    Apr 2 at 7:32






  • 3





    @AnttiHaapala it does not ignore the case a == 0 where there is no possible overflow, it just handles it differently.

    – chqrlie
    Apr 2 at 7:37


















29














You cannot detect signed int overflow. You have to write your code to avoid it.



Signed int overflow is Undefined Behaviour and if it is present in your program, the program is invalid and the compiler is not required to generate any specific behaviour.






share|improve this answer


















  • 3





    You can check you input values before doing a calculation to prevent overflow.

    – A.R.C.
    Apr 2 at 7:12






  • 7





    I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..

    – hetepeperfan
    Apr 2 at 7:17







  • 6





    @hetepeperfan It's because that's what the language standard says.

    – Sneftel
    Apr 2 at 8:40







  • 6





    @sneftel thats an authoritative argument lacking an authoritative source, despise it is probably correct. On top of that, standards make more sense to people, once they start to understand the language, which is perhaps a reason they visit stackoverflow in the first place.

    – hetepeperfan
    Apr 2 at 9:07






  • 5





    @hetepeperfan the reason for why the standard is written as it is, is for the most part outside the scope of Stack Overflow.

    – Antti Haapala
    Apr 2 at 12:51


















9














Signed operands must be tested before the addition is performed. Here is a safe addition function with 2 comparisons in all cases:



#include <limits.h>

int safe_add(int a, int b)
if (a >= 0)
if (b > INT_MAX - a)
/* handle overflow */
else
return a + b;

else
if (b < INT_MIN - a)
/* handle negative overflow */
else
return a + b;





If the type long long is known to have a larger range than type int, you could use this approach, which might prove faster:



#include <limits.h>

int safe_add(int a, int b) res < INT_MIN)
/* handle overflow */
else
return (int)res;







share|improve this answer































    3 Answers
    3






    active

    oldest

    votes








    3 Answers
    3






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    18














    You can predict signed int overflow but attempting to detect it after the summation is too late. You have to test for possible overflow before you do a signed addition.



    It's not possible to avoid undefined behaviour by testing for it after the summation. If the addition overflows then there is already undefined behaviour.



    If it were me, I'd do something like this:



    #include <limits.h>

    int safe_add(int a, int b)

    if (a >= 0)
    if (b > (INT_MAX - a))
    /* handle overflow */

    else
    if (b < (INT_MIN - a))
    /* handle underflow */


    return a + b;



    Refer this paper for more information. You can also find why unsigned integer overflow is not undefined behaviour and what could be portability issues in the same paper.



    EDIT:



    GCC and other compilers have some provisions to detect the overflow. For example, GCC has following built-in functions allow performing simple arithmetic operations together with checking whether the operations overflowed.



    bool __builtin_add_overflow (type1 a, type2 b, type3 *res)
    bool __builtin_sadd_overflow (int a, int b, int *res)
    bool __builtin_saddl_overflow (long int a, long int b, long int *res)
    bool __builtin_saddll_overflow (long long int a, long long int b, long long int *res)
    bool __builtin_uadd_overflow (unsigned int a, unsigned int b, unsigned int *res)
    bool __builtin_uaddl_overflow (unsigned long int a, unsigned long int b, unsigned long int *res)
    bool __builtin_uaddll_overflow (unsigned long long int a, unsigned long long int b, unsigned long long int *res)


    Visit this link.



    EDIT:



    Regarding the question asked by someone




    I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..




    The answer depends upon the implementation of the compiler. Most C implementations (compilers) just used whatever overflow behaviour was easiest to implement with the integer representation it used.



    In practice, the representations for signed values may differ (according to the implementation): one's complement, two's complement, sign-magnitude. For an unsigned type there is no reason for the standard to allow variation because there is only one obvious binary representation (the standard only allows binary representation).






    share|improve this answer

























    • Why extra parentheses? Also you could save one test on average with if (a >= 0) test overflow else test underflow return a + b;

      – chqrlie
      Apr 2 at 7:28












    • @chqrlie that is not sufficient because there is no possibility of overflow when a == 0.

      – Antti Haapala
      Apr 2 at 7:30











    • It is not necessary to test overflow if a == 0 but testing a just once saves one comparison if a < 0, which is half the cases.

      – chqrlie
      Apr 2 at 7:32






    • 8





      Also, both are technically called overflow. Underflow means that the value is too small in magnitude to be representable in a floating point variable.

      – Antti Haapala
      Apr 2 at 7:32






    • 3





      @AnttiHaapala it does not ignore the case a == 0 where there is no possible overflow, it just handles it differently.

      – chqrlie
      Apr 2 at 7:37















    18














    You can predict signed int overflow but attempting to detect it after the summation is too late. You have to test for possible overflow before you do a signed addition.



    It's not possible to avoid undefined behaviour by testing for it after the summation. If the addition overflows then there is already undefined behaviour.



    If it were me, I'd do something like this:



    #include <limits.h>

    int safe_add(int a, int b)

    if (a >= 0)
    if (b > (INT_MAX - a))
    /* handle overflow */

    else
    if (b < (INT_MIN - a))
    /* handle underflow */


    return a + b;



    Refer this paper for more information. You can also find why unsigned integer overflow is not undefined behaviour and what could be portability issues in the same paper.



    EDIT:



    GCC and other compilers have some provisions to detect the overflow. For example, GCC has following built-in functions allow performing simple arithmetic operations together with checking whether the operations overflowed.



    bool __builtin_add_overflow (type1 a, type2 b, type3 *res)
    bool __builtin_sadd_overflow (int a, int b, int *res)
    bool __builtin_saddl_overflow (long int a, long int b, long int *res)
    bool __builtin_saddll_overflow (long long int a, long long int b, long long int *res)
    bool __builtin_uadd_overflow (unsigned int a, unsigned int b, unsigned int *res)
    bool __builtin_uaddl_overflow (unsigned long int a, unsigned long int b, unsigned long int *res)
    bool __builtin_uaddll_overflow (unsigned long long int a, unsigned long long int b, unsigned long long int *res)


    Visit this link.



    EDIT:



    Regarding the question asked by someone




    I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..




    The answer depends upon the implementation of the compiler. Most C implementations (compilers) just used whatever overflow behaviour was easiest to implement with the integer representation it used.



    In practice, the representations for signed values may differ (according to the implementation): one's complement, two's complement, sign-magnitude. For an unsigned type there is no reason for the standard to allow variation because there is only one obvious binary representation (the standard only allows binary representation).






    share|improve this answer

























    • Why extra parentheses? Also you could save one test on average with if (a >= 0) test overflow else test underflow return a + b;

      – chqrlie
      Apr 2 at 7:28












    • @chqrlie that is not sufficient because there is no possibility of overflow when a == 0.

      – Antti Haapala
      Apr 2 at 7:30











    • It is not necessary to test overflow if a == 0 but testing a just once saves one comparison if a < 0, which is half the cases.

      – chqrlie
      Apr 2 at 7:32






    • 8





      Also, both are technically called overflow. Underflow means that the value is too small in magnitude to be representable in a floating point variable.

      – Antti Haapala
      Apr 2 at 7:32






    • 3





      @AnttiHaapala it does not ignore the case a == 0 where there is no possible overflow, it just handles it differently.

      – chqrlie
      Apr 2 at 7:37













    18












    18








    18







    You can predict signed int overflow but attempting to detect it after the summation is too late. You have to test for possible overflow before you do a signed addition.



    It's not possible to avoid undefined behaviour by testing for it after the summation. If the addition overflows then there is already undefined behaviour.



    If it were me, I'd do something like this:



    #include <limits.h>

    int safe_add(int a, int b)

    if (a >= 0)
    if (b > (INT_MAX - a))
    /* handle overflow */

    else
    if (b < (INT_MIN - a))
    /* handle underflow */


    return a + b;



    Refer this paper for more information. You can also find why unsigned integer overflow is not undefined behaviour and what could be portability issues in the same paper.



    EDIT:



    GCC and other compilers have some provisions to detect the overflow. For example, GCC has following built-in functions allow performing simple arithmetic operations together with checking whether the operations overflowed.



    bool __builtin_add_overflow (type1 a, type2 b, type3 *res)
    bool __builtin_sadd_overflow (int a, int b, int *res)
    bool __builtin_saddl_overflow (long int a, long int b, long int *res)
    bool __builtin_saddll_overflow (long long int a, long long int b, long long int *res)
    bool __builtin_uadd_overflow (unsigned int a, unsigned int b, unsigned int *res)
    bool __builtin_uaddl_overflow (unsigned long int a, unsigned long int b, unsigned long int *res)
    bool __builtin_uaddll_overflow (unsigned long long int a, unsigned long long int b, unsigned long long int *res)


    Visit this link.



    EDIT:



    Regarding the question asked by someone




    I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..




    The answer depends upon the implementation of the compiler. Most C implementations (compilers) just used whatever overflow behaviour was easiest to implement with the integer representation it used.



    In practice, the representations for signed values may differ (according to the implementation): one's complement, two's complement, sign-magnitude. For an unsigned type there is no reason for the standard to allow variation because there is only one obvious binary representation (the standard only allows binary representation).






    share|improve this answer















    You can predict signed int overflow but attempting to detect it after the summation is too late. You have to test for possible overflow before you do a signed addition.



    It's not possible to avoid undefined behaviour by testing for it after the summation. If the addition overflows then there is already undefined behaviour.



    If it were me, I'd do something like this:



    #include <limits.h>

    int safe_add(int a, int b)

    if (a >= 0)
    if (b > (INT_MAX - a))
    /* handle overflow */

    else
    if (b < (INT_MIN - a))
    /* handle underflow */


    return a + b;



    Refer this paper for more information. You can also find why unsigned integer overflow is not undefined behaviour and what could be portability issues in the same paper.



    EDIT:



    GCC and other compilers have some provisions to detect the overflow. For example, GCC has following built-in functions allow performing simple arithmetic operations together with checking whether the operations overflowed.



    bool __builtin_add_overflow (type1 a, type2 b, type3 *res)
    bool __builtin_sadd_overflow (int a, int b, int *res)
    bool __builtin_saddl_overflow (long int a, long int b, long int *res)
    bool __builtin_saddll_overflow (long long int a, long long int b, long long int *res)
    bool __builtin_uadd_overflow (unsigned int a, unsigned int b, unsigned int *res)
    bool __builtin_uaddl_overflow (unsigned long int a, unsigned long int b, unsigned long int *res)
    bool __builtin_uaddll_overflow (unsigned long long int a, unsigned long long int b, unsigned long long int *res)


    Visit this link.



    EDIT:



    Regarding the question asked by someone




    I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..




    The answer depends upon the implementation of the compiler. Most C implementations (compilers) just used whatever overflow behaviour was easiest to implement with the integer representation it used.



    In practice, the representations for signed values may differ (according to the implementation): one's complement, two's complement, sign-magnitude. For an unsigned type there is no reason for the standard to allow variation because there is only one obvious binary representation (the standard only allows binary representation).







    share|improve this answer














    share|improve this answer



    share|improve this answer








    edited Apr 3 at 8:31

























    answered Apr 2 at 7:17









    abhiaroraabhiarora

    2,55431533




    2,55431533












    • Why extra parentheses? Also you could save one test on average with if (a >= 0) test overflow else test underflow return a + b;

      – chqrlie
      Apr 2 at 7:28












    • @chqrlie that is not sufficient because there is no possibility of overflow when a == 0.

      – Antti Haapala
      Apr 2 at 7:30











    • It is not necessary to test overflow if a == 0 but testing a just once saves one comparison if a < 0, which is half the cases.

      – chqrlie
      Apr 2 at 7:32






    • 8





      Also, both are technically called overflow. Underflow means that the value is too small in magnitude to be representable in a floating point variable.

      – Antti Haapala
      Apr 2 at 7:32






    • 3





      @AnttiHaapala it does not ignore the case a == 0 where there is no possible overflow, it just handles it differently.

      – chqrlie
      Apr 2 at 7:37

















    • Why extra parentheses? Also you could save one test on average with if (a >= 0) test overflow else test underflow return a + b;

      – chqrlie
      Apr 2 at 7:28












    • @chqrlie that is not sufficient because there is no possibility of overflow when a == 0.

      – Antti Haapala
      Apr 2 at 7:30











    • It is not necessary to test overflow if a == 0 but testing a just once saves one comparison if a < 0, which is half the cases.

      – chqrlie
      Apr 2 at 7:32






    • 8





      Also, both are technically called overflow. Underflow means that the value is too small in magnitude to be representable in a floating point variable.

      – Antti Haapala
      Apr 2 at 7:32






    • 3





      @AnttiHaapala it does not ignore the case a == 0 where there is no possible overflow, it just handles it differently.

      – chqrlie
      Apr 2 at 7:37
















    Why extra parentheses? Also you could save one test on average with if (a >= 0) test overflow else test underflow return a + b;

    – chqrlie
    Apr 2 at 7:28






    Why extra parentheses? Also you could save one test on average with if (a >= 0) test overflow else test underflow return a + b;

    – chqrlie
    Apr 2 at 7:28














    @chqrlie that is not sufficient because there is no possibility of overflow when a == 0.

    – Antti Haapala
    Apr 2 at 7:30





    @chqrlie that is not sufficient because there is no possibility of overflow when a == 0.

    – Antti Haapala
    Apr 2 at 7:30













    It is not necessary to test overflow if a == 0 but testing a just once saves one comparison if a < 0, which is half the cases.

    – chqrlie
    Apr 2 at 7:32





    It is not necessary to test overflow if a == 0 but testing a just once saves one comparison if a < 0, which is half the cases.

    – chqrlie
    Apr 2 at 7:32




    8




    8





    Also, both are technically called overflow. Underflow means that the value is too small in magnitude to be representable in a floating point variable.

    – Antti Haapala
    Apr 2 at 7:32





    Also, both are technically called overflow. Underflow means that the value is too small in magnitude to be representable in a floating point variable.

    – Antti Haapala
    Apr 2 at 7:32




    3




    3





    @AnttiHaapala it does not ignore the case a == 0 where there is no possible overflow, it just handles it differently.

    – chqrlie
    Apr 2 at 7:37





    @AnttiHaapala it does not ignore the case a == 0 where there is no possible overflow, it just handles it differently.

    – chqrlie
    Apr 2 at 7:37













    29














    You cannot detect signed int overflow. You have to write your code to avoid it.



    Signed int overflow is Undefined Behaviour and if it is present in your program, the program is invalid and the compiler is not required to generate any specific behaviour.






    share|improve this answer


















    • 3





      You can check you input values before doing a calculation to prevent overflow.

      – A.R.C.
      Apr 2 at 7:12






    • 7





      I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..

      – hetepeperfan
      Apr 2 at 7:17







    • 6





      @hetepeperfan It's because that's what the language standard says.

      – Sneftel
      Apr 2 at 8:40







    • 6





      @sneftel thats an authoritative argument lacking an authoritative source, despise it is probably correct. On top of that, standards make more sense to people, once they start to understand the language, which is perhaps a reason they visit stackoverflow in the first place.

      – hetepeperfan
      Apr 2 at 9:07






    • 5





      @hetepeperfan the reason for why the standard is written as it is, is for the most part outside the scope of Stack Overflow.

      – Antti Haapala
      Apr 2 at 12:51















    29














    You cannot detect signed int overflow. You have to write your code to avoid it.



    Signed int overflow is Undefined Behaviour and if it is present in your program, the program is invalid and the compiler is not required to generate any specific behaviour.






    share|improve this answer


















    • 3





      You can check you input values before doing a calculation to prevent overflow.

      – A.R.C.
      Apr 2 at 7:12






    • 7





      I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..

      – hetepeperfan
      Apr 2 at 7:17







    • 6





      @hetepeperfan It's because that's what the language standard says.

      – Sneftel
      Apr 2 at 8:40







    • 6





      @sneftel thats an authoritative argument lacking an authoritative source, despise it is probably correct. On top of that, standards make more sense to people, once they start to understand the language, which is perhaps a reason they visit stackoverflow in the first place.

      – hetepeperfan
      Apr 2 at 9:07






    • 5





      @hetepeperfan the reason for why the standard is written as it is, is for the most part outside the scope of Stack Overflow.

      – Antti Haapala
      Apr 2 at 12:51













    29












    29








    29







    You cannot detect signed int overflow. You have to write your code to avoid it.



    Signed int overflow is Undefined Behaviour and if it is present in your program, the program is invalid and the compiler is not required to generate any specific behaviour.






    share|improve this answer













    You cannot detect signed int overflow. You have to write your code to avoid it.



    Signed int overflow is Undefined Behaviour and if it is present in your program, the program is invalid and the compiler is not required to generate any specific behaviour.







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered Apr 2 at 7:10









    Jesper JuhlJesper Juhl

    18k32647




    18k32647







    • 3





      You can check you input values before doing a calculation to prevent overflow.

      – A.R.C.
      Apr 2 at 7:12






    • 7





      I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..

      – hetepeperfan
      Apr 2 at 7:17







    • 6





      @hetepeperfan It's because that's what the language standard says.

      – Sneftel
      Apr 2 at 8:40







    • 6





      @sneftel thats an authoritative argument lacking an authoritative source, despise it is probably correct. On top of that, standards make more sense to people, once they start to understand the language, which is perhaps a reason they visit stackoverflow in the first place.

      – hetepeperfan
      Apr 2 at 9:07






    • 5





      @hetepeperfan the reason for why the standard is written as it is, is for the most part outside the scope of Stack Overflow.

      – Antti Haapala
      Apr 2 at 12:51












    • 3





      You can check you input values before doing a calculation to prevent overflow.

      – A.R.C.
      Apr 2 at 7:12






    • 7





      I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..

      – hetepeperfan
      Apr 2 at 7:17







    • 6





      @hetepeperfan It's because that's what the language standard says.

      – Sneftel
      Apr 2 at 8:40







    • 6





      @sneftel thats an authoritative argument lacking an authoritative source, despise it is probably correct. On top of that, standards make more sense to people, once they start to understand the language, which is perhaps a reason they visit stackoverflow in the first place.

      – hetepeperfan
      Apr 2 at 9:07






    • 5





      @hetepeperfan the reason for why the standard is written as it is, is for the most part outside the scope of Stack Overflow.

      – Antti Haapala
      Apr 2 at 12:51







    3




    3





    You can check you input values before doing a calculation to prevent overflow.

    – A.R.C.
    Apr 2 at 7:12





    You can check you input values before doing a calculation to prevent overflow.

    – A.R.C.
    Apr 2 at 7:12




    7




    7





    I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..

    – hetepeperfan
    Apr 2 at 7:17






    I think, it would be nice and informative to explain why signed int overflow undefined, whereas unsigned apperantly isn't..

    – hetepeperfan
    Apr 2 at 7:17





    6




    6





    @hetepeperfan It's because that's what the language standard says.

    – Sneftel
    Apr 2 at 8:40






    @hetepeperfan It's because that's what the language standard says.

    – Sneftel
    Apr 2 at 8:40





    6




    6





    @sneftel thats an authoritative argument lacking an authoritative source, despise it is probably correct. On top of that, standards make more sense to people, once they start to understand the language, which is perhaps a reason they visit stackoverflow in the first place.

    – hetepeperfan
    Apr 2 at 9:07





    @sneftel thats an authoritative argument lacking an authoritative source, despise it is probably correct. On top of that, standards make more sense to people, once they start to understand the language, which is perhaps a reason they visit stackoverflow in the first place.

    – hetepeperfan
    Apr 2 at 9:07




    5




    5





    @hetepeperfan the reason for why the standard is written as it is, is for the most part outside the scope of Stack Overflow.

    – Antti Haapala
    Apr 2 at 12:51





    @hetepeperfan the reason for why the standard is written as it is, is for the most part outside the scope of Stack Overflow.

    – Antti Haapala
    Apr 2 at 12:51











    9














    Signed operands must be tested before the addition is performed. Here is a safe addition function with 2 comparisons in all cases:



    #include <limits.h>

    int safe_add(int a, int b)
    if (a >= 0)
    if (b > INT_MAX - a)
    /* handle overflow */
    else
    return a + b;

    else
    if (b < INT_MIN - a)
    /* handle negative overflow */
    else
    return a + b;





    If the type long long is known to have a larger range than type int, you could use this approach, which might prove faster:



    #include <limits.h>

    int safe_add(int a, int b) res < INT_MIN)
    /* handle overflow */
    else
    return (int)res;







    share|improve this answer





























      9














      Signed operands must be tested before the addition is performed. Here is a safe addition function with 2 comparisons in all cases:



      #include <limits.h>

      int safe_add(int a, int b)
      if (a >= 0)
      if (b > INT_MAX - a)
      /* handle overflow */
      else
      return a + b;

      else
      if (b < INT_MIN - a)
      /* handle negative overflow */
      else
      return a + b;





      If the type long long is known to have a larger range than type int, you could use this approach, which might prove faster:



      #include <limits.h>

      int safe_add(int a, int b) res < INT_MIN)
      /* handle overflow */
      else
      return (int)res;







      share|improve this answer



























        9












        9








        9







        Signed operands must be tested before the addition is performed. Here is a safe addition function with 2 comparisons in all cases:



        #include <limits.h>

        int safe_add(int a, int b)
        if (a >= 0)
        if (b > INT_MAX - a)
        /* handle overflow */
        else
        return a + b;

        else
        if (b < INT_MIN - a)
        /* handle negative overflow */
        else
        return a + b;





        If the type long long is known to have a larger range than type int, you could use this approach, which might prove faster:



        #include <limits.h>

        int safe_add(int a, int b) res < INT_MIN)
        /* handle overflow */
        else
        return (int)res;







        share|improve this answer















        Signed operands must be tested before the addition is performed. Here is a safe addition function with 2 comparisons in all cases:



        #include <limits.h>

        int safe_add(int a, int b)
        if (a >= 0)
        if (b > INT_MAX - a)
        /* handle overflow */
        else
        return a + b;

        else
        if (b < INT_MIN - a)
        /* handle negative overflow */
        else
        return a + b;





        If the type long long is known to have a larger range than type int, you could use this approach, which might prove faster:



        #include <limits.h>

        int safe_add(int a, int b) res < INT_MIN)
        /* handle overflow */
        else
        return (int)res;








        share|improve this answer














        share|improve this answer



        share|improve this answer








        edited Apr 2 at 7:55

























        answered Apr 2 at 7:40









        chqrliechqrlie

        64k851108




        64k851108













            Popular posts from this blog

            Triangular numbers and gcdProving sum of a set is $0 pmod n$ if $n$ is odd, or $fracn2 pmod n$ if $n$ is even?Is greatest common divisor of two numbers really their smallest linear combination?GCD, LCM RelationshipProve a set of nonnegative integers with greatest common divisor 1 and closed under addition has all but finite many nonnegative integers.all pairs of a and b in an equation containing gcdTriangular Numbers Modulo $k$ - Hit All Values?Understanding the Existence and Uniqueness of the GCDGCD and LCM with logical symbolsThe greatest common divisor of two positive integers less than 100 is equal to 3. Their least common multiple is twelve times one of the integers.Suppose that for all integers $x$, $x|a$ and $x|b$ if and only if $x|c$. Then $c = gcd(a,b)$Which is the gcd of 2 numbers which are multiplied and the result is 600000?

            Barbados Ynhâld Skiednis | Geografy | Demografy | Navigaasjemenu

            Σερβία Πίνακας περιεχομένων Γεωγραφία | Ιστορία | Πολιτική | Δημογραφία | Οικονομία | Τουρισμός | Εκπαίδευση και επιστήμη | Πολιτισμός | Δείτε επίσης | Παραπομπές | Εξωτερικοί σύνδεσμοι | Μενού πλοήγησης43°49′00″N 21°08′00″E / 43.8167°N 21.1333°E / 43.8167; 21.133344°49′14″N 20°27′44″E / 44.8206°N 20.4622°E / 44.8206; 20.4622 (Βελιγράδι)Επίσημη εκτίμηση«Σερβία»«Human Development Report 2018»Παγκόσμιος Οργανισμός Υγείας, Προσδόκιμο ζωής και υγιές προσδόκιμο ζωής, Δεδομένα ανά χώρα2003 statistics2004 statistics2005 statistics2006 statistics2007 statistics2008 statistics2009-2013 statistics2014 statisticsStatistical Yearbook of the Republic of Serbia – Tourism, 20152016 statisticsStatistical Yearbook of the Republic of Serbia – Tourism, 2015Πληροφορίες σχετικά με τη Σερβία και τον πολιτισμό τηςΣερβική ΠροεδρίαΕθνικός Οργανισμός Τουρισμού της ΣερβίαςΣερβική ΕθνοσυνέλευσηΣερβίαεε