java学习-关于字符串String

时间:2023-03-10 06:44:30
java学习-关于字符串String

有必要总结记录一下java的学习,否则,永远只是记忆碎片化和always google(费时)

刚好,小伙伴给了一份自己做的review,在学习的过程中,update一下自己的见解和学习内容;

关于String:

 package string_keywords;
/**
* 参考url: http://developer.51cto.com/art/201106/266454.htm
*
* 常量池(constant pool)指的是在编译期被确定,并被保存在已编译的.class文件中的一些数据。它包括了关于类、方法、接口等中的常量,也包括字符串常量。
*
* 当一个字符串由多个字符串常量连接而成时,它自己肯定也是字符串常量;
* 多个常量连接;如果是像代码里s7的方式,字符串保存在堆?
*
* 当一个String实例str调用intern()方法时,Java查找常量池中是否有相同Unicode的字符串常量,如果有,则返回其的引用,如果没有,则在常量池中增加一个Unicode等于str的字符串并返回它的引用;
*
* http://www.importnew.com/10756.html
*
* */
public class Demo1 {
public static void main(String[] args) {
String s1 = "abc";
String s2 = "bcd";
String s3 = s1; //引用赋值,相当于s3 也指向了“abc”这个地址
String s4 = "abc";
String s5 = new String("abc");
String s6 = "ab"+"c";
String s7 = new String("ab")+"c";
String s10 = "c";
String s11 = "ab"+s10;
s1 += s2;//字符串的连接时,实际上是新开辟了一个字符串
System.out.println(s1);
System.out.println(s3);
System.out.println(s1 == s3);
System.out.println("s4==s3:"+(s4==s3)); //字符串常量池,s4 = "abc"实际上是指向了已有的abc的地址,因此用==判断时,指向一致,所以返回true
System.out.println("s5==s3:"+ (s5==s3)); // new String 的方式不同于直接赋值(常量池),而是新开辟了一个空间,因此判断字符串是否相等一般采用equals方法
System.out.println("s6==s3:"+(s6==s3)); //常量连接常量,还在常量池
System.out.println("s7==s3:"+(s7==s3)); //new的方式,不再是常量
String s8 = s4.intern();
String s9 = s5.intern();
System.out.println("s8==s3:"+(s8==s3));
System.out.println("s8==s4:"+(s8==s4));//s4本来就是指向常量池的,返回的intern地址当然也就是本身了
System.out.println("s9==s3:"+(s9==s3));// intern方法会去常量池查找是否存在该字符串常量,有则返回其地址,没有就加入常量池并返回地址
System.out.println("s11==s3:"+(s11==s3)); //在运行时通过连接计算出的字符串是新创建的
/*
* 疑问: String s = "a" +"bc";
* 我们知道a和bc是常量,abc存在于常量池,那么a和bc是否也存在于常量池?
* 如何验证呢?
*
* 内存跟常量池是什么关系?
* 为什么上述方式一般不推荐,而推荐使用StringBuffer,是因为扩大了常量池么?
*
* */
}
}

intern()补充:

        String s8 = s4.intern();
String s9 = s5.intern();
System.out.println("s8==s3:"+(s8==s3));//true
System.out.println("s9==s3:"+(s9==s3));//true

目前存在的疑问是:

1. 内存跟常量池的更深入理解

2. intern()方法是否对常量池做的是一种动态的update?