JAVA内存模型和多线程

先了解一下java内存模型

IBM:http://www.ibm.com/developerworks/cn/java/j-jtp03304/

http://www.ibm.com/developerworks/cn/java/j-jtp02244/

百度文库:

http://wenku.baidu.com/view/bc890df5f61fb7360b4c654b.html

 

对JMM的理解

 

volatile和synchronized的区别:


1.volatile本质是在告诉jvm当前变量在寄存器(工作内存)中的值是不确定的,需要从主存中读取;synchronized则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。
2.volatile仅能使用在变量级别;synchronized则可以使用在变量、方法、和类级别的
3.volatile仅能实现变量的修改可见性,并能保证原子性;而synchronized则可以保证变量的修改可见性和原子性
4.volatile不会造成线程的阻塞;synchronized可能会造成线程的阻塞。
5.volatile标记的变量不会被编译器优化;synchronized标记的变量可以被编译器优化

 

 

进程间通讯

Socket/RMI/WEBService/WebServer,   这些都可以实现直接的数据交换
Database/File,   这些可以实现间接的数据交换

看你的业务是否要求实时,   如果不需要,   用数据库交换比较简单

你可能感兴趣的:(java,多线程,webservice,百度,IBM)