博客
关于我
equals和==
阅读量:501 次
发布时间:2019-03-07

本文共 2406 字,大约阅读时间需要 8 分钟。

目录

==二元运算符和equals方法

根据数据类型的不同(值类型、引用类型、空类型),==运算符对于“值类型”和“空类型”,是比较他们的值;对于“引用类型”,比较的是他们在内存中的存放地址,即是否指向指向同一个对象。

Java中所有类都是继承于Object。Object类定义equals方法,这个方法的初始行为是比较对象的内存地址。实现如下:

public boolean equals(Object obj) {       return (this == obj);}

但有些类库对这个方法进行了重写,如String,Integer,Date等,而不再是比较堆内存中的存放地址。

String

String对equals进行重写,比较值是否相等。实现如下:

public boolean equals(Object anObject) {       if (this == anObject) {           return true;    }    if (anObject instanceof String) {           String aString = (String)anObject;        if (coder() == aString.coder()) {               return isLatin1() ? StringLatin1.equals(value, aString.value)                                : StringUTF16.equals(value, aString.value);        }    }    return false;}

因为String重写的equals方法,所以下述代码返回为true。

String str1 = new String("123");String str2 = new String("123");// truestr1.equals(str2);

由于==运算符对于“引用类型”仅比较是否指向同一片内存,所以new的两个String实例不相等。示例代码如下:

String str1 = new String("123");String str2 = new String("123");// falsestr1 == str2;

String包装器支持字面量赋值,当使用形如:stringInstance="xxx"方式创建字符串时,程序首先会在字符串缓冲池中寻找相同值的对象,如果池中无相同值的对象,则在池中添加一个值。所以以下代码值相等:

String str1 = "123";// truestr1 == "123";

但也应注意,如果使用new的方式创建字符串示例,则使用==会认为两边不相等。示例代码如下:

String str1 = new String("123");// falsestr1 == "123";

Integer

为提高Integer等包装器的性能,Java引入缓存池。Integer有两种实例方式:new Integer(xxx) 与 Integer.valueOf(xxx) 。两者的区别在于:new Integer(xxx)方式每次都会新建一个对象;Integer.valueOf(123) 会使用缓存池中的对象,多次调用会取得同一个对象的引用。在 Java 8 中,Integer 缓存池的大小默认为 -128~127。一旦超出这个范围,则不会缓存整数值。valueOf源码如下:

public static Integer valueOf(int i) {       if (i >= IntegerCache.low && i <= IntegerCache.high)        return IntegerCache.cache[i + (-IntegerCache.low)];    return new Integer(i);}

Short和Long

public static Short valueOf(short s) {       final int offset = 128;    int sAsInt = s;    if (sAsInt >= -128 && sAsInt <= 127) {    // must cache        return ShortCache.cache[sAsInt + offset];    }    return new Short(s);}
public static Long valueOf(long l) {       final int offset = 128;    if (l >= -128 && l <= 127) {    // will cache        return LongCache.cache[(int)l + offset];    }    return new Long(l);}

Float和Double

Float和Double未提供缓存池实现。使用时要特别注意。Float相关实现如下:

public static Float valueOf(float f) {       return new Float(f);}public Double(double value) {       this.value = value;}

参考

Java中equals和的区别

java:String使用equals和比较的区别
[Java]缓存池
<cnblogs.com/Pjson/p/8777940.html> 深入剖析Java中的装箱和拆箱(缓存池技术)

转载地址:http://ldvcz.baihongyu.com/

你可能感兴趣的文章
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>
multisim变压器反馈式_穿过隔离栅供电:认识隔离式直流/ 直流偏置电源
查看>>
mysql csv import meets charset
查看>>
multivariate_normal TypeError: ufunc ‘add‘ output (typecode ‘O‘) could not be coerced to provided……
查看>>
MySQL DBA 数据库优化策略
查看>>
multi_index_container
查看>>
MySQL DBA 进阶知识详解
查看>>
Mura CMS processAsyncObject SQL注入漏洞复现(CVE-2024-32640)
查看>>