Java面试题-Java核心基础-第七天(String)

目录

一、String、StringBuffer、StringBuilder的区别

二、String为什么是不可变的

三、字符串拼接用"+"还是用StringBuilder

[四、String 中的equals和Object中的equals的区别](#四、String 中的equals和Object中的equals的区别)

五、字符串常量池的作用了解吗?

[六、String s1 = new String("abc")是创建了几个对象?](#六、String s1 = new String("abc")是创建了几个对象?)

七、String中的intern方法有什么作用

八、String类型的变量和常量做"+"时发生了什么?


一、String、StringBuffer、StringBuilder的区别

  1. 是否可变

String由于属性被private 而且还被final修饰 而且String类还是final的 所以子类也无法进行修改 外界无法进行干扰,可以理解为常量 自然就不可变了

而StringBuffer和StringBuilder都实现了StringBuilderAbstract类 这个抽象类中定义了许多方法 例如:append replace 等方法 是可变的

  1. 线程是否安全

String中的属性可以理解为常量,自然是线程安全的

StringBuffer中的方法获取调用的方法都加了同步锁,因此是线程安全的

StringBulider中都没有加同步锁,自然线程不安全

  1. 性能

String每次对其修改都需要重新创建一个新的对象,因此对内存的消耗也比较大,性能不是很高

StringBuffer和StringBuilder因为都是可变的,效率较高,而StringBuilder因为方法都没有加锁,因此性能更高

总结三者的使用:

  1. 如果是少量的操作,可以使用String

  2. 如果是处于单线程环境,并且有大量的字符串操作,可以使用StringBuilder

  3. 如果是多线程环境,大量的字符串操作,使用StringBuffer

二、String为什么是不可变的

因为字符数组(后面是字节数组)被private修饰 也被final修饰 并且没有对外提供修改方法,因此无法直接操作

并且String类还是被final修饰的,所以也不能被子类所修改

三、字符串拼接用"+"还是用StringBuilder

使用+其实底层就是使用的StringBuilder的append方法

对于大量的拼接操作,推荐使用StringBuilder(当然这个在jdk9中得到了优化,也可以使用+),因为这只是一个StringBuilder对象在使用,而如果在循环中连续的对一个字符串使用+操作的话,就会创建多个StiringBuilder对象,不能进行复用,因此效率较低。

四、String 中的equals和Object中的equals的区别

String中的equals方法是得到了重写的,是比较的字符串的内容,而非Object中直接比较地址

五、字符串常量池的作用了解吗?

字符串常量池相当于就是缓存,是为了减少资源消耗的,避免重复的创建字符串对象

字符串常量池是存在于方法区中,一旦有一个String s = "abc"或者是Stirng s = new Sting("abc")

那么就会在字符串常量池中保留abc这个字面量 当下次再去 String s2 = "abc"时,此时无需再创建对象,直接使用字符串常量池中的即可,对于Stirng s4 = new Sting("abc")也一样,此时就只需要创建堆中的字符串对象,里面的char[]数组其实还是直接使用的字符串常量池中的字符串引用、

所以此时就只需要创建一个对象即可

六、String s1 = new String("abc")是创建了几个对象?

当字符串常量池中已存在abc字符串那么就只创建一个对象 否则需要不仅要创建堆上的字符串对象 还要创建字符串常量池中的(其实是创建那个char[]的,只是后面把这个引用放到字符串常量池中)

例如:

String s = "abc";/String s = new Stirng("abc")这个也会放到字符串常量池中

String s1 = new String("abc")

此时创建一个对象

七、String中的intern方法有什么作用

就是手动的将字符串引用放到字符串常量池中

如果字符串常量池中已经存在了引用,那么就直接返回这个引用 否则创建一个引用再返回

当然当创建String对象的时候,实际上就已经自动的将其引用放到字符串常量池中去了

八、String类型的变量和常量做"+"时发生了什么?

如果是常量 + 常量的方式 再编译的时候,编译器就会进行 一种叫做"常量折叠"的优化

例如 "abc" + "fg" 编译器就会直接将其优化成"abcfg" 不仅字符串这样 像其他的int long byte char等也会存在此优化

对于常量可以这样优化,但是一旦有变量,也就是对象引用 那么在编译的时候是无法对其进行优化的 因此只能创建一个新的创建 在堆上

String s1 = "abc" String s2 = "df"

s1 + s1 其实是 new StringBuilder().append(s1).append(s2).toString()

相关推荐
小凡敲代码3 天前
2025年最新Java后端场景面试题(大厂真题+解析)
java·程序员·java面试·java面试题·后端开发·java场景题·2025求职面试
GEM的左耳返19 天前
Java面试实战:企业级性能优化与JVM调优全解析
性能优化·并发编程·java面试·jvm调优·数据库优化·gc算法
GEM的左耳返20 天前
Java面试全攻略:Spring生态与微服务架构实战
spring boot·redis·spring cloud·微服务·kafka·java面试
GEM的左耳返20 天前
Java面试全方位解析:从基础到AI的技术交锋
spring boot·微服务·java面试·互联网大厂·rag技术·ai面试·java技术栈
GEM的左耳返20 天前
互联网大厂Java面试:微服务与AI技术深度交锋
spring cloud·ai·微服务架构·java面试·rag技术
GEM的左耳返20 天前
Java面试实战:从基础到架构的全方位技术交锋
spring boot·微服务·云原生·java面试·技术解析·ai集成
GEM的左耳返20 天前
Java面试新趋势:云原生与新兴框架实战解析
云原生·graalvm·服务网格·java面试·quarkus·micronaut
GEM的左耳返21 天前
Java AI面试实战:Spring AI与RAG技术落地
prompt工程·向量数据库·java面试·rag·ai应用·spring ai
会写代码的斯皮尔伯格23 天前
Spring Boot 3整合Spring AI实战:9轮面试对话解析AI应用开发
openai·微服务架构·java面试·rag·ollama·spring ai·spring boot 3
remCoding1 个月前
Java大厂面试实录:从Spring Boot到AI微服务架构的深度解析
spring boot·redis·kafka·java面试·spring ai·jakarta ee·ai微服务