synchronized 锁住的是变量和变量的操作,而volatile锁住的只是变量,而且该变量的值不能依赖它本身的值 volatile算是一种轻量级的同步锁
2015-10-22
当一个线程访问object的一个synchronized(this)同步代码块时,另一个线程仍然可以访问该object中的非synchronized(this)同步代码块。
当两个并发线程访问同一个对象object中的这个synchronized(this)同步代码块时,一个时间内只能有一个线程得到执行。另一个线程必须等待当前线程执行完这个代码块以后才能执行该代码块。
volatile和synchronized 的最大区别就是 前者不能保证变量或者代码操作的原子性,而后者可以。。。原子性:要么操作完全,要么不操作。即,要么操作为1要么为0。。而volatile可能值执行某项操作的一部分,比如 操作了0.6,这样子,算什么事儿嘛,对吧。。所以,这个就是区别。。。
个人总结,如有错误,望批评指正。发私信
个人总结,如有错误,望批评指正。发私信
2015-08-30
因为线程的执行本身就是不确定的,加了synchronized关键字只能确保互斥访问这段代码以及变量的可见性,即某线程在修改共享变量(通过自己的工作内存来修改)时,其他的所有线程无法获得共享变量的信息。所以synchronized并不能保证程序的执行顺序。所以即使加了synchronized也可能会出现0。顺序是随机的,看jVM内存以及CUP的调度了。
2015-08-30