Should autoboxing be avoided in Java?

前端 未结 5 1552
谎友^
谎友^ 2021-01-17 12:51

There are instances where a method expects a primitive type double and you pass a Double object as a parameter.

Since the compiler unboxes

相关标签:
5条回答
  • 2021-01-17 13:26

    It's a design-choice and not trivially answered for every case.

    There are several items that could influence your decision:

    Advantages:

    • Auto-boxing and auto-unboxing can make your code easier to read:

      Leaving out all the unnecessary .doubleValue() and Double.valueOf() reduces the visual noise and can make your code easier to read.

    • Auto-boxing allows you to easily use collections of primitive values (such as a List<Double>, ...)

    Disadvantages:

    • excessive, unnecessary auto-boxing and auto-unboxing can hinder your performance.

      For example, if you have an API that returns a double and another API that expects a double, but you handle the value as a Double in between, then you're doing useless auto-boxing.

    • auto-unboxing can introduce a NullPointerException where you don't expect it:

      public void frobnicate(Double d) {
        double result = d / 2;
        // ...
      }
      
    • using collections of auto-boxed values uses a lot more memory than a comparable double[] for example.

    0 讨论(0)
  • 2021-01-17 13:37

    You don't have to avoid autoboxing if talking about performance, JVM should handle that. The only thing you should consider is a readability of your code.

    0 讨论(0)
  • 2021-01-17 13:41

    Autoboxing should be avoided. It can lead to errors because of overloading and it has some performance impact. Nonetheless it may not be an issue in your application. But be aware of the impact.

    Here my post to that: https://effective-java.com/2010/05/the-advantages-and-traps-of-autoboxing/

    0 讨论(0)
  • 2021-01-17 13:46

    This is what Java Notes says on autoboxing:

    Prefer primitive types

    Use the primitive types where there is no need for objects for two reasons.

    1. Primitive types may be a lot faster than the corresponding wrapper types, and are never slower.
    2. The immutability (can't be changed after creation) of the wrapper types may make their use impossible.
    3. There can be some unexpected behavior involving == (compare references) and .equals() (compare values). See the reference below for examples.
    0 讨论(0)
  • 2021-01-17 13:48

    The rule of thumb is: always use primitives if possible.

    There are cases where this is not possible, like collections, so use wrappers only then.

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