java jdk1.7后 sting intern()方法与之前的区别

public static void main(String[] args) {
String s1 = new StringBuilder("计算机").append("软件").toString();//在堆中
System.out.println(s1.intern()==s1);// intern返回的值 指向堆中”计算机软件的引用" 与s1指向相同的一块堆内存,相同,返回true

String d= "class";//在方法区的常量池中 加入”class“字符串常量
String s2 = new StringBuilder("cla").append("ss").toString();//stringbuilder 在堆中创建
System.out.println(s2.intern()==s2);//如果已经在常量池中有,在jdk1.7后 intern()返回的是指向堆中字符串的引用,所以与方法区中的字符串常量class不同。返回false

//如果在jdk1.6及之前,两个都返回false。 因为之前的intern()直接返回在方法区的常量池中相应字符串的引用。 与stringbuilder在堆中的对象的引用肯定不同

}

时间: 2024-10-29 23:18:58

java jdk1.7后 sting intern()方法与之前的区别的相关文章

java基础知识回顾之---java String final类之intern方法

public class StringObjectDemo { /** * @param args */ public static void main(String[] args) { String hello = "Hello", lo = "lo"; System.out.print((hello == "Hello") + " ");//true System.out.print((Other.hello == hel

JAVA中String类的intern()方法的作用

一般我们平时很少使用到 intern这个方法,今天我就来解释一下这个方法是干什么的,做什么用的 首先请大家看一个例子: [java] view plaincopyprint? public static void main(String[] args) throws Exception { String a =  "b" ; String b =  "b" ; System.out.print( a == b); String c = "d" ;

StringBuffer转String后的intern方法

用StringBuffer生成字符串过程中,不同的拼接方式会影响最终字符串对象的位置. 案例一:声明对象中含直接定义的字符串 public class test { public static void main(String[] args) { // TODO Auto-generated method stub String str1=new StringBuffer("计算机").append("软件").toString(); String str2=new

java String的equals,intern方法(转载)

JAVA中的equals和==的区别 ==比较的是2个对象的地址,而equals比较的是2个对象的内容. 显然,当equals为true时,==不一定为true: 基础知识的重要性,希望引起大家的重视,包括自己在内 很多困惑和疑问而且均来自于最基础的知识 折腾了一阵子又查了查书,终于对 String 这个特殊的对象有了点感悟 public class TestString { public static void main(String[] args) { String s1 = "Monday

对于java的Sting.intern()的一些注意

今天翻看书时遇到了这样一个问题,对于String.intern()方法又有了一些认识和看法.首先我们看它的api 大意就是intern()方法会在常量池中记录首次出现的实例引用,但是在jdk1.6中却不是这样.jdk1.6中会将首次遇到的字符串实例 复制一份放在持久代里,返回的则是永久代中对于这个字符串的引用. 如下图 首先,这个运行环境是jdk1.7,运行后会分别的到true和false.这里由于StringBuilder 会在java堆上创建实例,intern()方法实现不会再复制实例, 只

String的内存和intern()方法

一.关于常量池 字符串在Java中用的非常得多,Jvm为了减少内存开销和提高性能,使用字符串常量池来进行优化. 在jdk1.7之前(不包括1.7),Java的常量池是在方法区的地方,方法区是一个运行时JVM管理的内存区域,是一个线程共享的内存区域,它用于存储已被虚拟机加载的类信息.常量.静态常量等. 运行时常量池是方法区的一部分. 来看一个图: (图片来自https://www.cnblogs.com/ysocean/p/8571426.html) 关于其他的内存分布就不在这介绍了. 而在jdk

Java技术——你真的了解String类的intern()方法吗

0.引言 转载请注明出处:http://write.blog.csdn.net/postedit/52291082 什么都先不说,先看下面这个引入的例子: String str1 = new String("SEU")+ new String("Calvin"); System.out.println(str1.intern() == str1); System.out.println(str1 == "SEUCalvin"); 本人JDK版本1

java String 中 intern方法的概念

1. 首先String不属于8种基本数据类型,String是一个对象. 因为对象的默认值是null,所以String的默认值也是null:但它又是一种特殊的对象,有其它对象没有的一些特性. 2. new String()和new String(“”)都是申明一个新的空字符串,是空串不是null: 3. String str=”kvill”:String str=new String (“kvill”);的区别: 在这里,我们不谈堆,也不谈栈,只先简单引入常量池这个简单的概念. 常量池(const

Java基础:JDK1.5后的新特性:自动拆装箱,以及注意事项

首先来看一段代码: 1 Integer x = new Integer(4); 2 Integer y = 4; 在JDK1.5版本后,以上两行代码都能编译通过,那是因为JDK1.5后加入新特性,自动装箱. 第一句代码是正常的创建对象方法,创建了一个Integer包装类对象. 而第二句中,当左边的Interger类型变量指向右边的int基本类型数据时,右边的基本数据类型会自动装箱成Integer对象,即隐式执行了new Integer(4). 再来一段代码: 1 Integer x = new