原子性问题
现在咱们来看并发编程中第二个问题,原子性问题。那么咱们的目标学习什么是原子性问题?在学习的过程中,咱们分成两步,第一步介绍原子性的概念,第二步通过一个案例来演示原子性问题。
咱们先来看原子性的概念,我们也是要先看一下前提,首先第一个啊也是要有多个线程,如果一个县城没有竞争是看不出问题的。第二我们要有共享变量,到时候多个线程来对共享变量操作。
原子性是指在一次或多次操作中,要么所有的操作都执行并且不会受其他因素的干扰而中断,要么所有的操作都不执行。
案例:
目标:演示原子性问题
步骤:
1、定义一个共享变量 number。
2、对 number 进行 1000 的 ++ 操作。
3、使用 5 个线程来进行。
public class AtomicityTestDemo01 {
// 1、定义一个共享变量 number
private static int number = 0;
public static void main(String[] args) throws InterruptedException {