摘要:在以下表达式中得到的是两个不同的信息我要创建一个字符串。否则,将此对象添加到池中,并且返回此对象的引用。的适用情况多个相同的大字符串同时出现的情况,例如可能出现多个相同消息的消息队列的设计。
1 一个最简单的程序:初学java有段时间了,但是昨晚忽然就被"asd"==getpara("password")搞得不开心了:确实JAVA很多东西和以前接触过的语言完全不一样,比如最简单的new String("asd") !=new String ("asd")。
public class A { public static void main(String args[]) { String s1 = "Hello"; String s2 = "Hello"; System.out.println(s1 == s2); } }
肯定很多人说,输出true,确实是输出true,s1和s2引用的是同一个东西嘛。但是这个程序如果换一种写法,那么肯定就不太一样了。
2 第一种变体:public class A { public static void main(String args[]) { String s1 = "Hello"; String s2 = new String("Hello"); System.out.println(s1 == s2); System.out.println(s1.equals(s2)); } }
或者:
public class A { public static void main(String args[]) { String s1 = new String("Hello"); String s2 = new String("Hello"); System.out.println(s1 == s2); System.out.println(s1.equals(s2)); } }
那么结果就有点不太确定了,有些人很坏的想到了,多带带拿出来,肯定至少有一个不会相等。
这两个程序的结果都是false true,原因很简单,JAVA是一个基本完全面向对象的语言,s1 == s2 判断的是他的引用(相当于内存地址、指针),equals则是使用这个对象自身的方法去判断值是否相等。
在以下表达式中:
String s1 = "Hello"; String s2 = new String("Hello");
JVM得到的是两个不同的信息:
1.我要创建一个“Hello”字符串。
2.我要创建一个新的“Hello”字符串,不要跟原来的一样的。
于是,s1 != s2.
顺序排列: public class A { public static void main(String args[]) { String s1 = new String("Hello"); String s2 = new String("Hello"); String s3 = "Hello"; s1=s1.intern(); s2=s2.intern(); System.out.println(s1 == s2); System.out.println(s1.equals(s2)); System.out.println(s3 == s2); System.out.println(s3.equals(s2)); } }
打乱顺序排列: public class A { public static void main(String args[]) { String s1 = new String("Hello"); String s3 = "Hello"; s1=s1.intern(); String s2 = new String("Hello"); s2=s2.intern(); //也可以String s2 = new String("Hello").intern(); System.out.println(s1 == s2); System.out.println(s1.equals(s2)); System.out.println(s3 == s2); System.out.println(s3.equals(s2)); } }
那么这次应该很清楚了=
两个object,但是中间加入了一些羞羞的东西,于是答案肯定是true true true true。
那么intern到底是什么。
当调用 intern 方法时,如果池已经包含一个等于此 String 对象的字符串(该对象由 equals(Object) 方法确定),则返回池中的字符串。
否则,将此 String 对象添加到池中,并且返回此 String 对象的引用。
intern的适用情况:多个相同的大字符串同时出现的情况,例如可能出现多个相同消息的消息队列的设计。
结论:该学JVM虚拟机了,Scala Up!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/64298.html
摘要:这两个操作符都是编译器默认引入了类,最后都调用方法返回对象,临时对象被回收,因此效率极为低下 Java String类笔记 声明 文章均为本人技术笔记,转载请注明出处https://segmentfault.com/u/yzwall String的不可变性 String的不可变性 // String declaration public final class String ...
摘要: env: os:ubuntu 16.04 x64openjdk8u //java.lang.String package java.lang; import java.lang.StringDebugHelper; //... public final class String{ final char value[];//remove private public bool...
摘要:因此,对应地我们可以翻译这段二进制字节码为这样的代码注意,这段代码并不能通过编译,因为源码这一层是不允许直接继承的,这个继承过程只允许在编译器内部解语法糖的过程中被编译器添加,添加之后的类才会有的访问标识符。 语法糖(Syntactic Sugar)的出现是为了降低我们编写某些代码时陷入的重复或繁琐,这使得我们使用语法糖后可以写出简明而优雅的代码。在Java中不加工的语法糖代码运行时可...
摘要:如感兴趣,可移步手写之基于动态创建对象手写之基于注解动态创建对象今天将详细介绍如何手写依赖注入,在运行过程中如何动态地为对象的属性赋值。完成后在中会有相关的包出现进行注入前需要创建工厂,在运行时从工厂中取出对象为属性赋值。 前两篇文章介绍了关于手写Spring IOC控制反转,由Spring工厂在运行过程中动态地创建对象的两种方式。如感兴趣,可移步: 手写Spring之IOC基于xml...
摘要:上一篇博客介绍了如何基于配置文件在运行时创建实例对象,这篇博客将介绍基于注解方式怎样实现对象的创建。方便测试,该类型分别创建两个单例和多例的类型。注意这种为对象注入属性值的方式耦合度较高,可根据情况使用。 上一篇博客介绍了如何基于xml配置文件在运行时创建实例对象,这篇博客将介绍基于注解方式怎样实现对象的创建。 废话不多说,直接上代码。 首先还是创建项目,由于这次不需要使用第三方的AP...
阅读 1310·2021-11-04 16:09
阅读 3515·2021-10-19 11:45
阅读 2406·2021-10-11 10:59
阅读 1020·2021-09-23 11:21
阅读 2771·2021-09-22 10:54
阅读 1147·2019-08-30 15:53
阅读 2617·2019-08-30 15:53
阅读 3488·2019-08-30 12:57