Is there a difference between BigDecimal(“0”) and BigDecimal.ZERO?

后端 未结 4 1407
忘了有多久
忘了有多久 2020-12-30 21:56

Either for comparisons or initialization of a new variable, does it make a difference which one of these you use?

I know that BigDecimal.ZERO is a 1.5 feature, so th

相关标签:
4条回答
  • 2020-12-30 22:33

    Before talking about runtime penalties, make sure that this piece of code matters. Set up profiling and measure the complete use case.

    Nevertheless, prefer Bigdecimal.ZERO as it's checked at compile time whereas you can accidentally type new BigDecimal("9"), which the compiler will accept, but which will cause bugs into your application.

    0 讨论(0)
  • 2020-12-30 22:39

    Using ZERO doesn't create a new object or require any parsing. Definitely the way to go.

    0 讨论(0)
  • 2020-12-30 22:40

    BigDecimal.ZERO is a predefined constant and therefore doesn't have to be evaluated from a string at runtime as BigDecimal("0") would be. It will be faster and won't require creation of a new object.

    If your code needs to run on pre-1.5, then you can use the (much maligned) Singleton pattern to create an object equivalent to BigDecimal.ZERO. The first time it is used, it would call BigDecimal("0") to create a zero object, and return that object on subsequent calls. Otherwise, if your code is running on a 1.5 system, your singleton object can just return BigDecimal.ZERO with no runtime penalty.

    0 讨论(0)
  • 2020-12-30 22:44

    Out of curiosity I checked to constructor for BigDecimal and it doesn't have any optimizations for the "0" string. So definitely yes, there's a difference.

    0 讨论(0)
提交回复
热议问题