String类的知识点

String类是final类故不可以继承

String与StringBuffer的区别

String的长度是不可变的,StringBuffer的长度是可变的。如果你对字符串中的内容经常进行操作,特别是内容要修改时,那么使用StringBuffer,如果最后需要String,那么使用StringBuffer的toString()方法

String类的构造

形如:String s = “hello world java” 这类的构造,是在方法区的字符串常量池中构造出一个final常量字符串(字符串常量池中同一字符串有且只有一个),String s直接指向这个常量字符串.任何对s的操作都不法修改常量字符串的值,比如 String s = “php是世界上最好的语言”,则是通过在字符串常量池中重新构造一个常量字符串,然后将s指向它来完成的.

指向同一常量字符串的字符串类的地址值相同,例子:String s =“java”,String ss =“java”,则s==ss是正确的

形如:String s = new String(“java”),这个构造首先会在堆中创建一个对象,然后又在方法区的字符串常量池中创建一个final常量字符串,将堆中的这个对象指向常量池中的这个字符串,然后我们构建的String s则指向堆中的这个对象.

因为这个特性,对于例如:String s = new String(“java”),String ss = new String(“java”) 因为s与SS分别在堆中的申明了两个各自不同的对象,这两个对象虽然指向方法区字符串常量池中同一个字符串,但他们两本身的地址值不相同,所以s==ss这个是错误的.

在这里插入图片描述



还一种是在类中申明的String类对象,创建的规则同上面两种,例:如果在Person类中的String类name的赋值是 String name = “Drug”,则直接在字符串常量池中创建唯一对象,而如果赋值是String name = new String(“Drug”),则会先在堆中创建对象,然后又在字符串常量池中创建唯一字符串常量,对象指向常量,我们的name对象则指向堆中的对象



对字符串进行concat操作时,如果两个字符串都是常量字符串,则结果还是常量字符串,如果有两个或一个是堆中对象的引用,则结果得到的String也会在堆中创建一个新的对象.

 String s1 = “a”;

说明:在字符串常量池中创建了一个字面量为"a"的字符串。

 s1 = s1 + “b”;

说明:实际上原来的“a”字符串对象已经丢弃了,现在在堆空间中产生了一个字符串s1+“b”(也就是"ab")。如果多次执行这些改变串内容的操作,会导致大量副本字符串对象存留在内存中,降低效率。如果这样的操作放到循环中,会极大影响程序的性能.

 String s2 = “ab”;

说明:直接在字符串常量池中创建一个字面量为"ab"的字符串。

 String s3 = “a” + “b”;

说明:s3指向字符串常量池中已经创建的"ab"的字符串。

String s4 = s1.intern();

说明:堆空间的s1对象在调用intern()之后,会将常量池中已经存在的"ab"字符串赋值给s4。

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值