String s1=“abc”//1个对象 常量区
String s2=new String("abc");//2个对象 一个常量区,一个在堆空间
String s3=s1+s2; //如果下面一行代码没有,则不使用s3 此处使用stringBulider 叠加最后toString 创建了2个对象 堆空间
System.out.println(s3); //如果输出了S3使用了S3 变成 S3=s1+s2 创建了一个对象 String对象
String s4="xyz"+"123";//官方编译器 1个对象“xyz123” 在常量区
//如果创建一个空串对象 优先S6 S7没有创建新的对象
String s5 = new String();//2个对象 一个在常量区,一个在堆空间,没有hash赋值 在后期使用map不需要重新算hash值
String s6 = new String("");//2个对象 一个在常量区 一个在堆空间 多一个hash赋值 ,在后期使用map 不用重新算hash
String s7 = "";//1个对象 在常量区
String s8 = “panda”;
String s9 = new String("panda");//需遍历字符串
String s10 = new String(s8);//推荐 直接引用s8 两者都行 s9 和 s10 都指向同一个底层
Filed filed = String.class.getDeclaredFiled("value");
field.setAccessible(true);
char[] chars = (char[])filed.get(s8);
char[1]='x';
//s9和s10都会变成pxnda;
String s12=s1+s2+s3+s4;
String s13=s1.concat(s2).concat.(s3).concat(s4);
//加号底层的原理
//当字符串长度在10位以内,在比较相等时使用hashcode;
s1.hashCode()==s2.hashCode();
String类的那些坑
最新推荐文章于 2022-08-31 11:35:10 发布