并发编程的基本概念
并发编程的三个概念
-
原子性
即一个操作要么全部执行,并且执行过程中不会被任何因素打断,要么就全部不执行。
典型的例子就是银行转账,将A账户中的钱转入B账户。这个过程必须要保证原子性,否 则会导致数据不一致。 -
可见性
可见性是用在多线程中的,指的是多个线程访问一个变量,其中一个线程修改了某个变量的值,那么其他线程可以立即看到修改的值。 -
有序性
程序执行的顺序是按照代码的先后顺序来执行的。3.1 指令重排序
public void testOrder() { int i = 1;//语句1 int j = 2;//语句2 int c = i + j; }
(1)那么在这个例子中,语句1和语句2并无关联性。那么jvm在真正执行这段代码时,可能发生指令重排序。
(2)一般来说,处理器为了提高程序运行效率,可能会对输入代码进行优化,它不保证程序中各个语句的执行先后顺序同代码中的顺序一致,但是它会保证程序最终执行结果和代码顺序执行的结果是一致的。
(3)虽然指令重排序不会影响单线程的执行结果,但是在多线程中就会存在问题。
private boolean inited = false; private void initContext() {} private void modifyContext() {} //线程1的代码 public void testThrea1() { initContext(); boolean inited = true; } //线程2的代码 public void testThread2() { while(!inited) { Thread.sleep(1000); } modifyContext(); }