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, ? 这些可以实现间接的数据交换
看你的业务是否要求实时, ? 如果不需要, ? 用数据库交换比较简单