当前位置: 首页 > article >正文

Java中String类型的创建关系、什么是常量池、以及StringBuilder/Buffer等

Java的String字符串使用

	String s1 = "Hello World";
	String s2 = "Hello World";
	String s3 = new String("Hello World");
	String s4 = new String("Hello World");
	System.out.println(s1==s2); // true
	System.out.println(s1==s3); // false
	System.out.println(s3==s4); // false

这段 Java 代码中,字符串 s1 和 s2 都使用字面量的方式赋值,它们在编译时会被放入常量池中。由于字符串常量池的特性,s1 和 s2 在常量池中的引用地址是相同的,因此 s1 == s2 的结果为 true。

而字符串 s3 和 s4 是通过 new 关键字创建的,它们在内存中是两个不同的对象,因此 s3 == s4 的结果为 false。
需要注意的是,字符串比较应该使用 equals() 方法,而不是 == 操作符。在上述代码中,使用:

System.out.println(s1/s2/s3/s4.equals(s1/s2/s3/s4));

输出结果都出结果都是true。




扩充知识1:什么是常量池

Java 常量池(Constant Pool)是 Java 虚拟机在执行程序时所维护的一块内存区域,它用于存放在编译期被确定,并被保存在 class 文件中的各种常量、符号引用和字面量等。

常量池中包含了以下类型的常量:

字面量:包括字符串、数字和布尔型常量。
符号引用:包括类和接口的全限定名、字段的名称和描述符、方法的名称和描述符等。
运行时常量:包括动态生成的字符串和类名等。

在 Java 中,字符串常量池和类常量池是两种常量池,分别用于存放字符串常量和类常量。字符串常量池用于存放字符串字面量,类常量池用于存放类和接口的全限定名、字段的名称和描述符、方法的名称和描述符等。

由于 Java 常量池的特性,相同的字符串字面量在常量池中只会被存储一次,因此多个引用变量可以共享同一个字符串字面量,从而减少了内存的占用。例如:

String s1 = "Hello World";
String s2 = "Hello World";
System.out.println(s1 == s2); // true

在这个例子中,字符串 “Hello World” 只会被存储一次,s1 和 s2 都引用同一个字符串字面量,因此 s1 == s2 的结果为 true。

需要注意的是,通过 new 关键字创建的字符串对象不会被放入常量池中,每次创建都会生成一个新的对象。例如:

String s3 = new String("Hello World");
String s4 = new String("Hello World");
System.out.println(s3 == s4); // false

在这个例子中,字符串 s3 和 s4 是通过 new 关键字创建的,它们在内存中是两个不同的对象,因此 s3 == s4 的结果为 false。




扩充知识2:String | StringBuilder | StringBuffer

String、StringBuilder 和 StringBuffer 都是 Java 中用于处理字符串的类,它们有以下的区别:

  1. String 类型是不可变的,一旦创建就不能修改。而 StringBuilder 和 StringBuffer 类型都是可变的,可以随时修改其值。
  2. 在字符串拼接时,如果使用 String 类型进行拼接,会导致创建大量的中间字符串对象,这会占用大量的内存和系统资源。而 StringBuilder 和 StringBuffer 类型则不会创建中间对象,可以直接对字符串进行修改,因此在频繁的字符串拼接操作中,StringBuilder 和 StringBuffer 的效率更高。
  3. StringBuilder 是线程不安全的,而 StringBuffer 是线程安全的。在多线程环境下,使用 StringBuffer 类型可以避免竞争条件的发生,但是会带来一定的性能开销。
  4. StringBuilder 和 StringBuffer 的 API 是类似的,但是 StringBuffer 中的方法都是 synchronized 关键字修饰的,因此在使用 StringBuffer 时需要考虑到同步的问题。而 StringBuilder 则没有这个问题。

因此,如果不需要考虑多线程的安全问题,可以使用 StringBuilder 类型来进行字符串的拼接和修改。如果需要考虑多线程的安全问题,则应该使用 StringBuffer 类型。如果只是进行字符串的读取和操作,可以使用 String 类型。


http://www.kler.cn/a/7665.html

相关文章:

  • 【硬件测试】基于FPGA的BPSK+帧同步系统开发与硬件片内测试,包含高斯信道,误码统计,可设置SNR
  • 之前手写的两个好用开源组件优化升级
  • 音视频入门基础:MPEG2-PS专题(6)——FFmpeg源码中,获取PS流的视频信息的实现
  • linux centos挂载未分配的磁盘空间
  • 通过 route 或 ip route 管理Linux主机路由
  • Improving Language Understanding by Generative Pre-Training GPT-1详细讲解
  • leetcode:验证回文串(详解)
  • 【音视频】zlmediakit总结二---webrtc编译
  • 【06】卷积
  • Spring Security 权限控制
  • mysql数据库简介
  • UE4 Sequence学习
  • 微软新Bing AI,带chat聊天写作等功能的搜索引擎简介
  • Nodejs+vue+elementui网上租车网站 vscode汽车租赁系统
  • 【MATLAB】一篇文章带你了解beatxbx工具箱使用
  • Zookeeper
  • Java多线程基础汇总(上)
  • 你写的C语言代码被翻译成可执行程序,需要这几步
  • 【ArcGIS Pro二次开发】(12):txt文件和Excel文件的读写
  • Java稀疏数组的应用
  • BERT: Pre-training of Deep Bidirectional Transformers forLanguage Understanding
  • 单例模式何以保证线程安全
  • Less 运行环境
  • ChatGPT能够干翻谷歌吗?
  • 蓝桥杯备考
  • 【Python】如何实现Redis构造简易客户端(教程在这)