java枚举线程安全问题_【JAVA并发第四篇】线程安全

1、线程安全

字数1w多了,老铁们点个赞吧o( ̄︶ ̄)o

多个线程对同一个共享变量进行读写操作时可能产生不可预见的结果,这就是线程安全问题。

线程安全的核心点就是共享变量,只有在共享变量的情况下才会有线程安全问题。这里说的共享变量,是指多个线程都能访问的变量,一般包括成员变量和静态变量,方法内定义的局部变量不属于共享变量的范围。

线程安全问题示例:

import lombok.extern.slf4j.Slf4j;/** * @Author FengJian * @Date 2021/1/27 10:59 * @Version 1.0 */@Slf4j(topic = "c.ThreadSafeTest")public class ThreadSafeTest { static int count = 0; public static void main(String[] args) throws InterruptedException { Thread t1 = new Thread("t1"){ @Override public void run() { for (int i = 0;i < 5000;i++){ count++; } } }; Thread t2 = new Thread("t2"){ @Override public void run() { for (int i = 0;i < 5000;i++){ count--; } } }; t1.start(); t2.start(); /** * join方法:使main线程与t1、t2线程同步执行,即t1、t2线程都执行完,main线程才会继续执行(但t1、t2之间依然是并行执行的) * 主要是为了等待两个线程执行完后,在main线程打印count的值 */ t1.join(); t2.join(); log.debug("count的值为:{}",count); }}

运行上述代码三次的结果如下:

[main] DEBUG c.ThreadSafeTest - count的值为:-904[main] DEBUG c.ThreadSafeTest - count的值为:-2206[main] DEBUG c.ThreadSafeTest - count的值为:73

在上述代码中,线程t1中count进行5000次自增操作,而线程t2中count则进行5000次自减操作。在两个线程都运行结束后,按照预期结果,count的值应为0。但由打印结果可知,count的值并不为0,且每次运行的结果都不一样。这就是多线程对共享变量进行操作出现的不可预见的结果,即常说的线程安全问题。

而线程安全,则指的是在多线程环境下,程序可以始终执行正确的行为,符合预期的逻辑。具体到上述代码,就是不论执行多少次,在t1、t2线程执行完毕后,count的值都应该始终符合预期的结果0。上述代码明显是线程不安全的。

2、出现线程安全的原因

线程安全是使用多线程必定会面临的问题,导致线程不安全的主要原因有以下三点:

①原子性:一个或者多个操作在 CPU 执行的过程中被中断

②可见性:一个线程对共享变量的修改,另外一个线程不能立刻看到

③有序性:序执行的顺序没有按照代码的先后顺序执行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值