Java并发包小结

原创
2018/09/21 09:58
阅读数 45

1、Lock

    Lock功能对应关键字synchrozied功能,lock和unlock方法用于加锁和释放锁。等待锁的线程加入到等待链表中,同时阻塞线程,锁释放时,从等待链表中取出等待的线程执行,取等待的线程分公平与非公平两种方式,公平方式取第一个等待的线程,非公平方式当前正在获取锁的线程可能立刻执行,而不用加入到等待队列中,排队执行。

2、Condition

    Condition的await和singal方法对应Object的wait和notify方法,JDK中阻塞队列使用Condition实现,使用两个Condition对象,分别是notFull和notEmpty,协调阻塞集合的存取操作。

3、LinkedBlockQueue  ArrayBlockQueue

    LinkedBlockQueue基于链表实现,不用一开始就分配一块空闲的内存空间,因此适合用于不确定集合大小的情况,避免预先分配内存,初始化时可以不指定队列大小,默认为Integer.MAX_VALUE,指定大小后不可以扩容。

    ArrayBlockQueue基于数组实现,构造参数至少有初始容量这个参数,指定容量后不可扩容,同时会预先分配内存空间。

4、DelayQueue

    DelayQueue用于把需要延迟处理的数据存放到集合中,比如订单超时后取消订单,不用定时任务定时轮询。业务线程把延迟数据添加到DelayQueue中,另外一个线程从队列中poll数据,如果数据时间没有到期,返回Null,只有到期后才返回。

 

待补充...

展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部