Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Common underflow and overflow exceptions

I am trying to get a hold of overflow and underflow exceptions in java, but couldn't get any nice tutorial. Specifically I wish to learn

  1. How are they different from each other?
  2. What are the subclasses of these exceptions?
  3. In which scenario they are thrown?
  4. Which of them can be handled and how?
  5. What are the best practice related to them?

Any link to useful tutorial will do

like image 597
Ravi Gupta Avatar asked Jan 28 '10 13:01

Ravi Gupta


People also ask

What are overflow and underflow conditions explain with example?

Underflow happens when we try to pop an item from an empty stack. Overflow happens when we try to push more items on a stack than it can hold. An error is a mistake that is probably unrecoverable. An exception is an error that can often be handled, so the program can recover.

How do you determine underflow and overflow?

Detecting Overflow and Underflow We can detect overflow and underflow by checking, if b >= 0 , that a > MAX - b , otherwise with b < 0 , that a < MIN - b . The reason this works is that, if b is greater than or equal to 0, we can safely subtract it from MAX (if it were negative, subtracting it would cause an overflow).

What is overflow exception?

An OverflowException is thrown at run time under the following conditions: An arithmetic operation produces a result that is outside the range of the data type returned by the operation.

What are overflow and underflow errors in context of array?

Overflow and underflow are both errors resulting from a shortage of space. On the most basic level, they manifest in data types like integers and floating points. Unlike the physical world, the number stored in a computer exists in a discrete number of digits.


2 Answers

In Java arithmetic, overflow or underflow will never throw an Exception. Instead, for floating point arithmetic the value is set as Not a number, 'infinite' or zero.

To test for these you can use the static methods: isNaN or isInfinite using the appropriate wrapper classes. You can handle this as appropriate. Example:

double d1 = 100 / 0.;
if (Double.isNaN(d1)) {
    throw new RuntimeException("d1 is not a number");
}
if (Double.isInfinite(d1)) {
    throw new RuntimeException("d1 is infinite");
}

For certain operations you can get an ArithmeticException, for example when dividing by zero in Integer maths.

I just asked a related question about a complete project style way to handle this.

like image 154
Pool Avatar answered Sep 30 '22 08:09

Pool


Okay, the OP talked about wanting to know about both stack overflow and arithmetic overflow, as well as their corresponding underflow. Here goes....

  1. Arithmetic overflow happens when a number gets too big to fit in its value type. For example, an int holds values between -231 and 231-1, inclusive. If your number goes over these limits, an overflow occurs, and the number "wraps around". These do not cause an exception to be generated in Java.
  2. Arithmetic underflow happens when a floating point number gets too small to distinguish very well from zero (the precision of the number got truncated). In Java, these do not cause an exception either.
  3. Stack overflow happens when you call a function, that calls another function, that then calls another, then another...and the function call stack gets too deep. You get a StackOverflowError when that happens.
  4. Stack underflow doesn't happen in Java. Its runtime system is supposed to prevent that sort of stuff from happening.

To answer the OP's other question (see comments), when you overstep the boundaries of an array, an IndexOutOfBoundsException is issued.

like image 38
Chris Jester-Young Avatar answered Sep 30 '22 07:09

Chris Jester-Young