为什么说String是线程安全的???
为什么说String是线程安全的???
String是final修饰的类,是不可变的,所以是线程安全的。
不可变类的线程都是安全的,因为他们都是只读的
一、Java String类为什么是final的?
1.为了实现字符串池
2.为了线程安全
3.为了实现String可以创建HashCode不可变性
二、Java final的用途?
1、final可以修饰类,方法和变量,
2、final修饰的类,不能被继承,即它不能拥有自己的子类,
3、final修饰的方法,不能被重写,
4、final修饰的变量,无论是类属性、对象属性、形参还是局部变量,都需要进行初始化操作。
三、查看JDK String的源码:
final的修饰使得value数组不可变,引用不能变,但是数组本身可以改变啊,例如
final也可以将数组本身改变的,这个时候,起作用的还有private,正是因为两者保证了String的不可变性。
**那么为什么保证String不可变呢?**因为只有当字符串是不可变的,字符串池才有可能实现。
字符串池的实现:可以在运行时节约很多heap空间,因为不同的字符串变量都指向池中的同一个字符串。
那为什么String有substring和replace方法呢?我们还是看源码,这里我分析一个substring,replace方法类似,jdk源码如下
前面不多说,就是获取字符串截取的起始位置和截取的长度
returen那里renturn this只是返回当前的字符串,没有修改字符串。后面如果是截取也是用new String生成一个新的对象,所以这个方法根本没有改变原有字符串,总之记住了:
因为字符串是不可变的,所以是多线程安全的,同一个字符串实例可以被多个线程共享。
这样便不用因为线程安全问题而使用同步。字符串自己便是线程安全的。
因为字符串是不可变的,所以在它创建的时候HashCode就被缓存了,不需要重新计算。这就使得字符串很适合作为Map中的键,字符串的处理速度要快过其它的键对象。这就是HashMap中的键往往都使用字符串。
作为Map中的键,字符串的处理速度要快过其它的键对象。这就是HashMap中的键往往都使用字符串。