线程安全第一大类问题之运行结果出错
a++多线程下出现消失的请求现象
逻辑代码(注释很详细,直接看代码):
package controller;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.atomic.AtomicInteger;
/**
* 第一种:运行结果出错
* 演示计数不准确,减少,找出具体出错位置
*/
public class MultiThreadError implements Runnable {
static MultiThreadError instance = new MultiThreadError();
private int index = 0;
//用两个原子整型记录真正的执行数和出错数
static AtomicInteger realIndex = new AtomicInteger();
static AtomicInteger wrongCount = new AtomicInteger();
//CyclicBarrier这个工具类可以让线程根据我们需要在某一个地方等待,知道要等待的人员都就绪,然后一起出发。2这个参数值等待的线程数
static volatile CyclicBarrier cyclicBarrier1 = new CyclicBarrier(2);
static volatile CyclicBarrier cyclicBarrier2 = new CyclicBarrier(2);
final boolean[] marked = new boolean[1000000];
public static void main(String[] args) throws InterruptedException {
Thread thread1 = new Thread(i

本文探讨了线程安全的第一大类问题——在多线程环境下,由于并发导致的运行结果出错。通过示例代码(a++操作)展示了在多线程下可能出现的‘消失的请求’现象,并提示读者可以查阅上篇内容理解什么是线程安全,以及下篇将要讨论的线程安全第二大类问题——死锁。
最低0.47元/天 解锁文章
1391

被折叠的 条评论
为什么被折叠?



