The API docs says
All of the details in the Spec concerning overflow are ignored, as BigIntegers are made as large as necessary to accommodate the results of an operation.
Does this implies BigInteger will never overflow assuming you have sufficient memory available ? If so why do we let some "type" overflow and some don't ?
As the language evolves, will it favor the types which hide overflowing mechanism from the programmers ?
You read it right, it will never overflow. Although, it won't create more RAM for you :)
BigInteger will never overflow assuming you have enough memory to handle it.
To answer your question of why we let some types overflow and not others:
BigInteger is not really a type. It's a class. It's a wrapper class designed to give you the same functionality as an int, but allows you to use numbers as big as you need without the worry of overflow.
Types do overflow because they are simply a couple of bytes (exact amount depends on the type) of memory, and once that small amount of memory overflows, so do the numbers.
No class "overflows" unless it is specifically designed to do so (or if you run out of resources). A class is defined with enough memory for everything it contains, which would mostly be references to other classes or other data structures.
BigInteger never overflows! It's of an arbitrary size, so it can accomodate a number as large as your memory (and Java heap) can accomodate.
Correct, BigInteger never overflows, it uses software operations and dynamic allocation to store arbitrarily sized numbers.
As with all things in computing, "arbitrarily sized" is anothe way of saying "until you run out of resources on the underlying system".
That entirely depends on how it is backed. If it's backed by for example a plain vanilla primitive
int
, then it will obviously overflow atInteger.MAX_VALUE
. Primitives have clear overflow borders, while those for Objects depends on how they're backed/programmed.