多线程之synchronized锁字符串对象的一个易错点

前段时间讲了synchronized锁方法,锁this对象,锁非this对象。具体可以看往期的文章,今天我们来看下锁非this对象(锁String对象)的一个注意点。在Java中是有常量池缓存的功能的,就是说如果我先声明了一个String str1 = “a”; 再声明一个一样的字符串的时候,取值是从原地址去取的,也就是说是同一个对象。这也就导致了在锁字符串对象的时候,可以会取得意料之外的结果(字符串一样会取得相同锁),下面看一个例子介绍。

多线程之synchronized锁字符串对象的一个易错点

测试方法

这里synchronized锁的是字符串对象,如果不是同一个对象,那么两个线程就可以异步进来。下面看下线程和测试结果。

多线程之synchronized锁字符串对象的一个易错点

线程A

这里建两个线程,线程B和线程A一样就不贴出来了,都是将“xc”字符串传给上面的测试方法。下面看下测试结果。

多线程之synchronized锁字符串对象的一个易错点

测试结果

从结果可以就看到,线程B并没有进来,也就说明两个线程持有的是同一个锁,即字符串对象是同一个。这就是String常量池会带来的问题。所以在大多数情况下,同步代码块synchronized代码块不使用String作为锁对象,而采用其他。

多线程之synchronized锁字符串对象的一个易错点

修改测试方法

这里将线程A和线程B传进来的参数用new方式创建对象。这样就可以保证不是同一个对象。从而打印的会是异步打印。

所以大家在使用字符串作为同步锁对象的时候要注意~~

谢谢大家的收看,喜欢的关注一波~~~

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值