Java String类的比较运算
面试题:(多选)以下返回true的有()
A. "beijing" == "beijing"
B. "beijing".equals(new String("beijing"))
C. "beijing" == new String("beijing")
D. String a = "beijing";
String b = "beijing";
a == b
E. String a = new String("beijing")
String b = new String("beijing");
a == b
答案是 A,B,D
private void testSring() {
if ("beijing" == "beijing") {
System.out.println("this is equal1");
}
if ("beijing".equals(new String("beijing"))) {
System.out.println("this is equal2");
}
if ("beijing" == new String("beijing")) {
System.out.println("this is equal3");
}
String a = "beijing";
String b = "beijing";
if (a == b) {
System.out.println("this is equal4");
}
String m = new String("beijing");
String n = new String("beijing");
if (m == n) {
System.out.println("this is equal5");
}
}
执行结果为:
this is equal1
this is equal2
this is equal4
以下分析转载自:http://blog.sina.com.cn/s/blog_6fd8a5870100qimb.html
Java中的String类是一种复合数据类型,比较String 类的是否相等也有2种办法。"=="和equals()两种。
String 是一个系统定义的类----不是基本数据类型,有关字符串处理的方法非常多,有时候两个“一样”的字符串做相等的比较运算时会得到true的结果,可是有的时候得到的结果却是false,这是为什么呢?
要彻底的弄清这两个字符串的相等比较,还得从系统的内存分配着手。
1 栈和堆的区别
栈和堆都是java 在ram中的数据存储区,java自动管理栈和堆,程序员不能直接设置栈和堆。
1.1栈
栈的存取速度仅次于位于cpu中的寄存器,比堆的存取速度快,栈中数据项的插入和删除,只能在栈顶的一端完成,栈的操作特性后进先出。栈中存放一些基本类型的变量和对象句柄,栈中的数据可以共享,缺点::存放在栈中的数据大小与生存期必须是确定的,缺乏灵活性,比如有如下例子:
int a = 3; int b = 3;
编译器先处理int a = 3,首先它会在栈中创建一个整形变量为a的引用,然后在栈中查找有没有值为3的存储单元,如果没有就开辟一个存放值为3的存储单元,然后将a指向这个值为3的地址,接着处理int b = 3,在创建完变量b的引用后,由于栈中已经有了值为3的地址,这样就出现了a和b同时指向3的情况。
假如再有a= 4,在编译器内部它会重新搜索栈中是否有值为4的存储单元,如果没有,重新开辟地吃存放4的存储单元;如果有则直接将a指向这个地址。因此a值的改变不会影响到b的值。
1.2堆
堆是一个运行时数据区,类的对象从中分配空间,通过如new等指令建立。堆的优点是可以动态的分配内存大小。生存期也不必事先告诉编译器,java的垃圾收集器会自动回收不再使用的数据。但缺点是,由于要在运行时动态非配内存,存取速度比较慢。
2 字符串 “==”的比较
String是一个特殊的包装类数据。当测试两个包装类的引用是否指向同一个对象时,用“==”。
String 类的对象有两种形式创建:
形式1:String str = “abc”;
形式 2:String str = new String(“abc”) ;
2.1 两者都为第一种形式创建的对象的比较
String str1 = “abc”;
String str2 = “abc”;
用语句String str1 = “abc”;创建对象java内部将此语句转换为以下几个步骤:
(1) 先定义一个名为str1 的对String类的对象引用变量。
(2) 在栈中查找有没有存放值为“abc”的存储单元,接着创建一个新的Sting类的对象0,并将对象0指向这个存储单元,而且在栈中记下这个引用的对象0.如果已经有了值为“abc”的地址则查找对象0,并返回对象0的地址。
(3) 将str1指向对象0的地址。Str1指向存在栈中的数据的引用。
String str2 =”abc”;在栈中创建了一个对象引用str2.因为栈中已经有一个值为“abc”的对象0,因此jvm创建了两个引用str1和str2,但只创建了一个对象,而且这两个引用都指向了这个对象,所以这里str1 == str2.
2.2 同为第二种形式创建的两个对象的比较
如:String str1 = new String(“abc”);
String str2 = new String(“abc”);
System.out.println(str1 ==str2);
系统在栈内存中分别创建了两个对象引用变量str1和str2,同时在堆内存中创建了两个对象。两个引用变量分别表示两个不同的对象,如图所示,
无论堆内存中是否有相同的数据存在,也不会像栈中的数据共享。因此str1 != str2.
2.3两种不同形式创建对象的比较
String str1 = new String(“abc”);
String str2 = “abc”;
System.out.println(str1 == str2); //false
Str1和str2是栈中创建的两个引用,str1 指向了堆中的一个对象,而str2则指向了栈中的一个对象,即两个引用分别指向不同的两个对象,所以str1 != str2.
3 字符串值的比较
如果要比较两个字符串的值就用equals()方法。如:str1.equals(str2)只要str1和str2的字面值相等结果就为true.
4 结论
(1) String str = “abc”;指向String类的引用被创建了。至于这个引用是否指向了一个新的对象,根据上下文来考虑。
(2) String str = new String(“abc”);在栈中创建了一个对象的引用srt,str指向在堆中创建的新对象。该对象值为“abc”的String类。
(3) 当比较包装类里面的数值是否相等时,用equals方法,当测试两个包装类的引用是否指向一个对象的时候,用“==”。
Java String类的比较运算的更多相关文章
- Java String类详解
Java String类详解 Java字符串类(java.lang.String)是Java中使用最多的类,也是最为特殊的一个类,很多时候,我们对它既熟悉又陌生. 类结构: public final ...
- JAVA String 类
java String类中的常用方法:public char charAt(int index)返回字符串中第index个字符:public int length()返回字符串的长度:public i ...
- Java String类具体解释
Java String类具体解释 Java字符串类(java.lang.String)是Java中使用最多的类,也是最为特殊的一个类,非常多时候,我们对它既熟悉又陌生. 类结构: public fin ...
- Java 11 - Java String类
Java String类 字符串广泛应用在Java编程中,在Java中字符串属于对象,Java提供了String类来创建和操作字符串. 创建字符串 创建字符串最简单的方式如下: String gree ...
- Java-Runoob:Java String 类
ylbtech-Java-Runoob:Java String 类 1.返回顶部 1. Java String 类 字符串广泛应用 在Java 编程中,在 Java 中字符串属于对象,Java 提供了 ...
- Java——String类
body, table{font-family: 微软雅黑; font-size: 10pt} table{border-collapse: collapse; border: solid gray; ...
- Java String类和StringBuffer类
1.String类 用于字符串操作,本质是字符数组char[ ]. String对象的值是不可变的,即当你修改一个String对象的类容,JVM不会改变原来的对象,而是生成一个新String对象. 2 ...
- Java String类的常用方法
String(byte[ ] bytes):通过byte数组构造字符串对象. String(char[ ] value):通过char数组构造字符串对象. String(Sting original) ...
- Java String类中的intern()方法
今天在看一本书的时候注意到一个String的intern()方法,平常没用过,只是见过这个方法,也没去仔细看过这个方法.所以今天看了一下.个人觉得给String类中加入这个方法可能是为了提升一点点性能 ...
随机推荐
- POJ 2411
Mondriaan's Dream Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 9614 Accepted: 5548 ...
- zoj - 3209 - Treasure Map(精确覆盖DLX)
题意:一个 n x m 的矩形(1 <= n, m <= 30),现给出这个矩形中 p 个(1 <= p <= 500)子矩形的左下角与右下角坐标,问最少用多少个子矩形能够恰好 ...
- Cocos2d-x 2地图步行实现:SPFA算法
本文乃Siliphen原创,转载请注明出处:http://blog.csdn.net/stevenkylelee 上一节<Cocos2d-x 地图行走的实现1:图论与Dijkstra算法> ...
- 屌丝程序猿赚钱之道之taobao 2
续上篇,之前写的案例,都是比較0基础的. 案例4: 代写情书.软文.论文等等. 这是我一个同学的真实故事. 我隔壁寝室的小王平时没事就爱谢谢博客.逛逛论坛.大二的时候接触了威客网,開始在网上 ...
- 一个带动画的页面底部的TabBar的实现
有时有这样一个需求,页面底部有几个图标能够点击,假设一个screenWidth显示不下这些图标,则这一列图标最后一个是more,点击more,能够通过动画展示两列图标 这样来增加layout中: &l ...
- 关于Hbase的cache配置
关于Hbase的cache配置 在hbase中的hfilecache中,0.96版本号中新添加了bucket cache, bucket cache通过把hbase.offheapcache.perc ...
- Android学习之 AChartEngine 图表绘制
Android 开源图表绘制工具AChartEngine地址:http://code.google.com/p/achartengine/ AChartEngine Android实现图表绘制和展示( ...
- 三种方法让你的Service不被“一键加速”和系统杀掉
基本上大家都知道提高service优先级能够在非常大程度上让你的service免于由于内存不足而被kill,当然系统仅仅是在此时先把优先级低的kill掉,假设内存还是不够,也会把你的service干掉 ...
- 在JAVA中使用LUA脚本记,javaj调用lua脚本的函数(转)
最近在做一些奇怪的东西,需要Java应用能够接受用户提交的脚本并执行,网络部分我选择了NanoHTTPD提供基本的HTTP服务器支持,并在Java能承载的许多脚本语言中选择了很久,比如Rhino,Jy ...
- 191. Number of 1 Bits Leetcode Python
Write a function that takes an unsigned integer and returns the number of '1' bits it has (also know ...