Java String之intern()方法深入分析
来源:互联网 发布:电脑usb001端口是哪个 编辑:程序博客网 时间:2024/03/29 03:05
- 背景
在 Java 语言中有8中基本类型和一种比较特殊的引用类型String。这些类型为了使他们在运行过程中速度更快,更节省内存,都提供了一种常量池的概念。常量池就类似一个JAVA系统级别提供的缓存。
8种基本类型的常量池都是系统协调的,String类型的常量池比较特殊。它的主要使用方法有两种:
1) 直接使用双引号声明出来的String对象会直接存储在常量池中;
2) 如果不是用双引号声明的String对象,可以使用String提供的intern方法。intern 方法会从字符串常量池中查询当前字符串是否存在,若不存在就会将当前字符串放入常量池中。 - 美团技术团队Blog
- String的intern()方法:
如果常量池中存在当前字符串, 就会直接返回当前字符串. 如果常量池中没有此字符串, 会将此字符串放入常量池中后, 再返回。 - jdk7中的改变:
1) 将String常量池 从 Perm 区(或者说是:方法区)移动到了 Java Heap区
2) String#intern 方法时,如果存在堆中的对象,会直接保存对象的引用,而不会重新创建对象。
以下针对jdk1.7:
public static void main(String[] args){ String s1 = new String("1");//s1指向堆中的对象 String s2 = "1";//s2指向常量池中的对象 s1.intern();//不管怎样都会返回常量池中的地址 System.out.println(s1.intern() == s2);//true(常量池,常量池) System.out.println(s1 == s2);//false(堆,常量池) String s3 = new String("1")+new String("1");//s3指向堆中的对象,且常量池中没有"11"对象 s3.intern();//如果存在堆中的对象,会直接保存对象的引用,而不会重新创建对象 String s4 = "11"; System.out.println(s3 == s4);//true }
但是:
public static void main(String[] args){ String s1 = new String("1"); String s2 = "1"; s1.intern(); System.out.println(s1 == s2);//false String s3 = new String("1")+new String("1"); String s4 = "11"; s3.intern(); System.out.println(s3 == s4);//false(堆,常量池) }
0 0
- Java String之intern()方法深入分析
- 深入分析Java String.intern()方法
- 深入java String.intern()
- String之intern()方法
- java String.intern() 方法
- Java String.intern()方法
- 【Java深入】String.intern()详解
- 占小狼之-Java进阶之路-深入分析String.intern和String常量的实现原理
- java-String类深入剖析和 intern()方法解析
- 深入理解Java虚拟机(6)--String.intern()方法
- Java中String类的intern()方法深入理解。
- java-String中的 intern方法
- Java -- String的intern方法
- java-String中的 intern方法
- java-String中的 intern方法
- java String中的intern方法
- java-String中的 intern方法
- java中String.intern() 方法
- JLINK驱动刷新之WIN7
- hdoj 5124 lines【】
- java静态代码块、初始化块和构造方法的执行顺序
- 2817:木棒 【递归+剪枝】
- 【Oracle】无宕机迁移更换asm磁盘
- Java String之intern()方法深入分析
- exej4打包jar图文教程
- gradle eclipse web模板项目构建
- 3.0创建mongoDB客户端链接
- 2,XCode的快捷键
- 剑指offer之65 滑动窗口的最大值问题
- Andrid的网络开发技术
- 3.0MongoDB对一个collection的常用操作
- leetcode-Remove Linked List Elements