从Java多线程可见性谈Happens-Before原则
Happens-Before是一个非常抽象的概念,然而它又是学习Java并发编程不可跨域的部分。本文会先阐述Happens-Before在并发编程中解决的问题―― 多线程可见性 ,然后再详细讲解Happens-Before原则本身。 Java多线程可见性 在现代操作系统上编写并发程序时,除了要注意线程安全性(多个线程互斥访问临界资源)以外,还要注意多线程对共享变量的可见性,而后者往往容易被人忽略。 可见性是指当一个线程修改了共享变量的值,其它线程能够适时得知这个修改。在单线程环境中,如果在程序前面修改了某个变量的值,后面的程序一定会读取到那个变量的新值。这看起来很自然,然而当变量的写操作和读操作在不同的线程中时,情况却并非如此。 /** *《Java并发编程实战》27页程序清单3-1 */ public class NoVisibility { private static boolean ready ; private static int number; private static class ReaderThread extends Thread { public void run () { while (! ready ) { Thread. yield (); } System.out. println (number); } } public static void