volatile該關鍵字是主要使用的場合是字啊多個線程中能夠感知實例的變量被更改了而且能夠獲取到最新的值進行使用,也就是用多線程讀取共享變量的時候能夠獲取到最新的值使用。不能保障原子性java
若是你在jvm中傳遞-server時候會致使這個運行的棧會在私有內存中而不是在共享內存中。多線程
而synchronized是指的是同步的關鍵字,也就是說這個是線程同步的關鍵字。能夠保障數據在併發的時候保證數據的原子性併發
測試代碼:jvm
MyThreadByVolatileide
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 }
VolatileTestspa
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則有code