我从其他参考资料中学到了很多&所以Double有很多缺点。
与双原语数据类型相比,有双重缺点:
现在,我知道有一些操纵,我们可以做的双倍。JavaDoc,但是这些方法中的大多数(85%)都是静态的,所以它不是一个巨大的优势。还有一件事我知道那双不能是空的。
Double doubleClass = null; // Is valid
double doubleType = null; // Results in NPE在所有这些缺点之后,我不明白为什么我们会在现实生活中使用双倍而不是双倍。一些能给出一个真实世界的例子和解释。
谢谢
发布于 2014-10-10 12:59:49
使用Double有很多主要原因。
您应该尽可能使用基元类型,而不是双倍类型。
发布于 2014-10-10 12:41:14
据我所知,有两个主要原因。
Double是一个引用类型,因此可以是null。有时候这些信息是很重要的。(设想一个场景,当用户可以在表单中填写各种字段时,有些字段是可选的,您希望了解字段是否已填入。null值是一个相当好的指示符,表示表单字段是空的。)但一般来说,只要有可能,您就应该使用原语类型。
发布于 2014-10-10 12:41:42
Double是基元双上的包装类。框架有一些容器,如List、Set等。这些容器的问题是它们不能接受原语。因此,double被隐式转换为Double并插入到集合中(自动装箱)。
Double doubleClass = null; // Is valid --> Double is not a primitive. So, you can get NPE if you do doubleClass.someInstanceLevelFieldOrMethod.
double doubleType = 5.5; //is a primitive。
另外,Double比double慢,因为与原语不同的类有一些记账/开销。
PS : Double提供了许多APi /方法来完成一些事情。示例- Double.parseDouble(TypeX value)从TypeX的值创建一个新的双值
https://stackoverflow.com/questions/26299623
复制相似问题