Java Core II 读书笔记(一)多线程
1多线程
线程的状态:New 、Runnable、Blocked、Dead。
线程的属性:优先级,守护线程、线程分组。
线程同步:对于java的线程同步有两种方式:一种利用Lock,创建newCondition锁住一个临界区;另外一种方式是synchronized关键字实现同步,对于java本身,一个对象是隐式添加了synchronized同步的,但是对于方法却没有这样。synchronized比较简洁,但是却不能中断一个在试图获取锁的线程,不能很好的与计算机硬件原语很好的映射,不能使用多个条件用到锁上,而且不能设置超时。
对于使用线程同步,作者建议使用Java本身的线程同步包(如同步队列)去实现,如果非要自己实现同步最好是用Synchronized,因为使用比较简单,不容易出错;最后才考虑使用Lock实现同步。
即使使用了Lock或者Synchronized也未必线程安全,对于现代的编译器,对于不同处理器上多个线程去访问同一内存地址可能访问到不同值(缓存),必须对锁变量添加Volatile关键字,可以告诉虚拟机和编译器这个域可能被另外的线程更新。
如果一个域要绝对安全,必须有Volatile关键字;域是final的,并且在构造器调用完成后被访问;对于域的访问有锁的保护。
Java实现线程同步:安全的集合类、线程池、java同步器(障栅栏、倒计时门栓、交互器、同步队列、同步散列表、信号量)。
posted on 2009-09-01 22:57 john.huang 阅读(293) 评论(0) 编辑 收藏 举报