1.及时失败(fail-fast):迭代器发现容器在迭代过程中被修改时,就会抛出一个ConcurrentModificationException异常
2.阻塞队列提供了可阻塞的put和take方法,以及支持定时的offer和poll方法。如果队列已经满了,那么put方法将阻塞直到有空间可用;如果队列为空,那么take方法将会阻塞直到有元素可用。
阻塞队列提供了offer方法,如果数据项不能添加到队列中,那么返回一个失败状态。
3.SynchronousQueue不会为队列中元素维护存储空间,它维护一组线程,这些线程在等待着把元素加入或移出队列。
4.Deque和BlockingDeque分别对Queue和BlockingQueue进行了扩展,Deque是一个双端队列,实现了在队列头和队列尾的高效插入和移除。具体实现包括ArrayDeque和LinkedBlockingDeque。双端队列适用于工作密取(Work Stealing)模式。
5.中断是一种协作机制。一个线程不能强制其他线程停止正在执行的操作而去执行其他的操作。
6.CountDownLatch是一种灵活的闭锁实现,可以使一个或多个线程等待一组事件完成。
7.Semaphore管理者一组虚拟的许可(permit),许可的初始数量可以通过构造函数来指定。acquire()将阻塞直到有许可(或直到被中断或操作超时)。release()将返回一个许可给信号量。