Java Core II 读书笔记(一)多线程

1多线程

线程的状态:New RunnableBlockedDead

线程的属性:优先级,守护线程、线程分组。

线程同步:对于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编辑  收藏  举报

导航