I've faced java.math.BigDecimal
and android.icu.math.BigDecimal
as I require to use BigDecimal
in the project.
I've realized that the Android BigDecimal
requires API level 24
What is the different between these two classes? I wonder if there is any performance optimization in Android implementation?
android.icu.math.BigDecimal
is part of the ICU library (International Components for Unicode). Since API 24 the Android framework exposes some of the ICU4J classes for you to use. The Android documentation on Unicode and I18N support states:
Some classes in the
java
andandroid
packages have equivalents to those found in ICU4J. However, ICU4J often provides broader support for standards and languages.
Don't be confused by the above quote because ICU classes do reside in the android
package. They were moved to android.icu
from com.ibm.icu
in order to avoid conflicts.
Regarding BigDecimal
in particular: I found a discussion on the internet which concludes that BigDecimal
was available in ICU before it was available in Java and is kept in the library for compatibility purposes.
Bottom line: use whatever implementation you like, but java.math.BigDecimal
is less likely to be deprecated in the future.