为什么说String是线程安全的???

为什么说String是线程安全的???

String是final修饰的类,是不可变的,所以是线程安全的。

不可变类的线程都是安全的,因为他们都是只读的

一、Java String类为什么是final的?

1.为了实现字符串池

​ 2.为了线程安全

​ 3.为了实现String可以创建HashCode不可变性

二、Java final的用途

1、final可以修饰类,方法和变量,

2、final修饰的类,不能被继承,即它不能拥有自己的子类,

3、final修饰的方法,不能被重写,

4、final修饰的变量,无论是类属性、对象属性、形参还是局部变量,都需要进行初始化操作。

三、查看JDK String的源码:  为什么说String是线程安全的???

final的修饰使得value数组不可变,引用不能变,但是数组本身可以改变啊,例如

为什么说String是线程安全的???
为什么说String是线程安全的???
 final也可以将数组本身改变的,这个时候,起作用的还有private,正是因为两者保证了String的不可变性

**那么为什么保证String不可变呢?**因为只有当字符串是不可变的,字符串池才有可能实现。

字符串池的实现:可以在运行时节约很多heap空间,因为不同的字符串变量都指向池中的同一个字符串。

那为什么String有substring和replace方法呢?我们还是看源码,这里我分析一个substring,replace方法类似,jdk源码如下

为什么说String是线程安全的???
 前面不多说,就是获取字符串截取的起始位置和截取的长度

returen那里renturn this只是返回当前的字符串,没有修改字符串。后面如果是截取也是用new String生成一个新的对象,所以这个方法根本没有改变原有字符串,总之记住了:

因为字符串是不可变的,所以是多线程安全的,同一个字符串实例可以被多个线程共享。

这样便不用因为线程安全问题而使用同步。字符串自己便是线程安全的。

因为字符串是不可变的,所以在它创建的时候HashCode就被缓存了,不需要重新计算。这就使得字符串很适合作为Map中的键,字符串的处理速度要快过其它的键对象。这就是HashMap中的键往往都使用字符串。

作为Map中的键,字符串的处理速度要快过其它的键对象。这就是HashMap中的键往往都使用字符串。