热门标签 | 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



推荐阅读
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • 重入锁(ReentrantLock)学习及实现原理
    本文介绍了重入锁(ReentrantLock)的学习及实现原理。在学习synchronized的基础上,重入锁提供了更多的灵活性和功能。文章详细介绍了重入锁的特性、使用方法和实现原理,并提供了类图和测试代码供读者参考。重入锁支持重入和公平与非公平两种实现方式,通过对比和分析,读者可以更好地理解和应用重入锁。 ... [详细]
  • linux进阶50——无锁CAS
    1.概念比较并交换(compareandswap,CAS),是原⼦操作的⼀种,可⽤于在多线程编程中实现不被打断的数据交换操作࿰ ... [详细]
  • 微软头条实习生分享深度学习自学指南
    本文介绍了一位微软头条实习生自学深度学习的经验分享,包括学习资源推荐、重要基础知识的学习要点等。作者强调了学好Python和数学基础的重要性,并提供了一些建议。 ... [详细]
  • 在Android开发中,使用Picasso库可以实现对网络图片的等比例缩放。本文介绍了使用Picasso库进行图片缩放的方法,并提供了具体的代码实现。通过获取图片的宽高,计算目标宽度和高度,并创建新图实现等比例缩放。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 使用Ubuntu中的Python获取浏览器历史记录原文: ... [详细]
  • ZSI.generate.Wsdl2PythonError: unsupported local simpleType restriction ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 本文介绍了Codeforces Round #321 (Div. 2)比赛中的问题Kefa and Dishes,通过状压和spfa算法解决了这个问题。给定一个有向图,求在不超过m步的情况下,能获得的最大权值和。点不能重复走。文章详细介绍了问题的题意、解题思路和代码实现。 ... [详细]
  • 本文介绍了在Android开发中使用软引用和弱引用的应用。如果一个对象只具有软引用,那么只有在内存不够的情况下才会被回收,可以用来实现内存敏感的高速缓存;而如果一个对象只具有弱引用,不管内存是否足够,都会被垃圾回收器回收。软引用和弱引用还可以与引用队列联合使用,当被引用的对象被回收时,会将引用加入到关联的引用队列中。软引用和弱引用的根本区别在于生命周期的长短,弱引用的对象可能随时被回收,而软引用的对象只有在内存不够时才会被回收。 ... [详细]
  • STL迭代器的种类及其功能介绍
    本文介绍了标准模板库(STL)定义的五种迭代器的种类和功能。通过图表展示了这几种迭代器之间的关系,并详细描述了各个迭代器的功能和使用方法。其中,输入迭代器用于从容器中读取元素,输出迭代器用于向容器中写入元素,正向迭代器是输入迭代器和输出迭代器的组合。本文的目的是帮助读者更好地理解STL迭代器的使用方法和特点。 ... [详细]
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社区 版权所有