1.5,5
synchronized关键字
lock和condition的关键点:
1.锁用来保护代码片断,任何时刻只允许一个线程执行被保护的代码。
2.锁可以管理试图进入被保护代码短的线程。
3.锁可以拥有一个或多个相关的条件对象。
4.每个条件对象管理那些已进入被保护代码段但还不能运行的线程。
Condtion的await()和signalAll()方法等价于thread的wait()和notifyAll()方法
1.5.8 死锁
当程序挂起后,就是所有线程都挂起后,按CTRL+/,将会得到所有线程的列表。每一个线程都有一
个堆栈踪迹,它会告诉你当前在哪里阻塞了。
1.5.9 公平
Lock lock = new ReentrantLock(true);//设置为公平锁策略。
公平锁策略会优待那些等待了最长时间的线程。但是,这会大大影响性能。所以默认下是非公平的。
1.5.10 锁测试和超时
java.util.concurrent.locks.Lock 5.0
boolean tryLock()
如果锁可用,则获取锁,并立即返回值 true
。如果锁不可用,则此方法将立即返回值 false
。
boolean tryLock(long time,TimeUnit unit)
尝试获得锁,但阻塞时间不会超过给定的值;如果成功返回true;
void lockInterruptibly()
获得锁,但是会不确定地发生阻塞。如果线程被中断,抛出一个InterruptedException异常。
1.5.11 读/写锁
1)创建一个ReentrantReadWriteLock 对象
private ReentrantReadWriteLock rwl = new ReentrantReadWriteLock ();
2)抽取读锁和写锁
private Lock readlock = rwl.readLock();
private Lock writeock = rwl.writeLock();
3)对所有访问者加读锁
public double getTotalBalance()
{
readlock.lock();
...................
}
1.6 阻塞队列
ConcurrentHashMap具有一些很有用地方法来进行原子行地关联插入和关联移出操作。
putIfAbsent(key,value);
如果指定键已经不再与某个值相关联,则将它与给定值关联。这等价于:
if (!map.containsKey(key)) return map.put(key, value); else return map.get(key);
replace(key,oldValue,newValue);
只有目前将键的条目映射到给定值时,才替换该键的条目。这等效于:
if (map.containsKey(key) && map.get(key).equals(oldValue)) { map.put(key, newValue); return true; } else return false;
1.7.3 旧的线程安全地集合
JDK1.2中,Vector和hashtable被弃用了,虽然他们是线程安全地动态数组!
替代它们的是ArrayList和hashMap,虽然这些不是线程安全的,但可以利用一下操作实现线程安全:
List synchList = Collections.synchronizedList(new ArrayList());
Map synchMap= Collections.synchronizedList(new HashMap());
但是如果你想迭代这个Collection的化,必须使用一个同步块:
synchronized (synchMap)
{
Iterator iter = synchMap.keySet().iterator();
}
1.9 执行器
1.9.1线程池