volatile該關鍵字是主要使用的場合是字啊多個執行緒中可以感知例項的變數被更改了並且可以獲取到最新的值進行使用,也就是用多執行緒讀取共享變數的時候可以獲取到最新的值使用。不能保障原子性
如果你在jvm中傳遞-server時候會導致這個執行的棧會在私有記憶體中而不是在共享記憶體中。
而synchronized是指的是同步的關鍵字,也就是說這個是執行緒同步的關鍵字。可以保障資料在併發的時候保證資料的原子性
測試程式碼:
MyThreadByVolatile
1 package cn.lonecloud; 2 /** 3 * 使用volatile關鍵字進行限制 4 * @Title: MyThreadByVolatile.java 5 * @Package cn.lonecloud 6 * @Description: 7 * @author lonecloud 8 * @date 2016年9月5日 下午4:08:00 9 */ 10 public class MyThreadByVolatile extends Thread{ 11 //新增volatile關鍵字 12 volatile public static int m=0; 13 @Override 14 public void run() { 15 for (int i = 0; i < 1000; i++) { 16 m++; 17 } 18 System.out.println(Thread.currentThread().getName()+" "+m); 19 } 20 }
MyThreadBySynchronized
1 package cn.lonecloud; 2 /** 3 * 使用synchronized同步方法進行 4 * @Title: MyThreadBySynchronized.java 5 * @Package cn.lonecloud 6 * @Description: 7 * @author lonecloud 8 * @date 2016年9月5日 下午4:08:56 9 */ 10 public class MyThreadBySynchronized extends Thread { 11 public static int m=0; 12 @Override 13 synchronized public void run() { 14 for (int i = 0; i < 100; i++) { 15 m++; 16 } 17 System.out.println(Thread.currentThread().getName()+" "+m); 18 } 19 }
VolatileTest
1 package cn.lonecloud; 2 /** 3 * 測試類 4 * @Title: VolatileTest.java 5 * @Package cn.lonecloud 6 * @Description: 7 * @author lonecloud 8 * @date 2016年9月5日 下午4:09:15 9 */ 10 public class VolatileTest { 11 public static void main(String[] args) { 12 Thread thread[]=new Thread[100]; 13 for (int i = 0; i < 100; i++) { 14 thread[i]=new MyThreadByVolatile();//結果為99591總是少 15 // thread[i]=new MyThreadBySynchronized(); 16 } 17 for (int i = 0; i < thread.length; i++) { 18 thread[i].start(); 19 } 20 } 21 }
結果如果使用volatile沒有保證資料的穩定
使用synchronized則有