热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

线程安全列表

2019独角兽企业重金招聘Python工程师标准一、非阻塞式线程安全列表ConcurrentLinkedDequeConcurrentLinkedDequed

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

一、非阻塞式线程安全列表 ConcurrentLinkedDeque


ConcurrentLinkedDeque deque &#61; new ConcurrentLinkedDeque<>();for (int i&#61;0;i<10;i&#43;&#43;){Thread t1 &#61; new Thread(() -> {for (int j &#61; 0; j <10000; j&#43;&#43;) {deque.add(String.valueOf(j));}});t1.start();t1.join();
}System.out.println(deque.size()); //100000

deque.getFirst(); deque.getLast();

//返回列表中的第一个和最后一个。元素不会被移除&#xff0c;如果列表为空将抛出NoSuchElementException

deque.peek();deque.peekFirst();deque.peekLast();

  //返回中第一个和最后一个&#xff0c;元素不会被移除&#xff0c;如果列表为空返回null

deque.pollLast();deque.pollFirst();

//返回列表中第一个和最后一个&#xff0c;并移除元素。不会抛出异常

deque.remove();deque.removeFirst();deque.removeLast();

  //返回第一个和最后一个&#xff0c;并移除元素。列表为空将抛出异常

 

二、阻塞式线程列表

LinkedBlockingDeque blockingDeque &#61; new LinkedBlockingDeque<>();


阻塞与非阻塞的主要区别&#xff1a;阻塞式列表在插入和删除操作时&#xff0c;如果列表已满或为空&#xff0c;操作不被立即执行&#xff0c;而是将调用这个操作的线程阻塞
直到操作可以执行成功。
 

三、按优先级排序的阻塞式线程安全列表 PriorityBlockingQueue

PriorityBlockingQueue blockingQueue &#61; new PriorityBlockingQueue<>();

PriorityBlockingQueue 中的每个元素都要实现 Comparable接口。元素越大越靠后

特性&#xff1a;它是阻塞数据结构。当它的方法被调用并且不能立即执行时&#xff0c;调用这个方法的线程将被阻塞直到方法执行成功。

四、带延迟元素的线程安全列表

DelayQueue delayQueue &#61; new DelayQueue<>();


 1.它可以存放带有激活日期的元素&#xff0c;当从该列表取取值时&#xff0c;未来的元素将被忽略
 2.它的元素必须实现  Delayed 接口

五、并发随机数 ThreadLocalRandom

 

ThreadLocalRandom.current().nextInt();

 

 

 

 


转:https://my.oschina.net/u/2552286/blog/1924808



推荐阅读
author-avatar
我摸你马匹
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有