java并发队列
阻塞队列
常见的阻塞队列有ArrayBlockingQueue,LinkedBlockingDeque,LinkedBlockingQueue,这些队列有界且可以阻塞线程
ArrayBlockingQueue
ArrayBlockingQueue是有界的阻塞队列,LinkedBlockingDeque通过数组、非空和非满Condition、RantrantLock实现了线程安全。空的时候take阻塞,满的时候put阻塞
java并发初探LinkedBlockingQueue
LinkedBlockingQueue是有界的阻塞队列,通过head,last节点,putLock插入锁,takeLock取锁、非空和非满condition、单向链表实现了线程安全的阻塞队列,空的时候take阻塞,满的时候put阻塞
java并发初探LinkedBlockingQueue
LinkedBlockingQueue是有界的阻塞队列,通过head,last节点,putLock插入锁,takeLock取锁、非空和非满condition、单向链表实现了线程安全的阻塞队列,空的时候take阻塞,满的时候put阻塞
非阻塞队列
java并发初探ConcurrentLinkedQueue
ConcurrentLinkedQueue是线程安全的无界队列,通过volatile和CAS操作保证了线程安全。
例子
阻塞队列当满的时候put元素回阻塞,实现队列接口的LinkedList在多线程的时候会跑出ConcurrentModifExeception异常
package com.java.javabase.thread.collection;
import lombok.extern.slf4j.Slf4j;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.Map;
import java.util.Queue;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ConcurrentLinkedQueue;
import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.LinkedBlockingQueue;
/**
* @author
*/
@Slf4j
public class BlockingQueueTest {
/* public static Queue<String> queue = new ArrayBlockingQueue<String>(20);
public static ArrayBlockingQueue<String> queue = new ArrayBlockingQueue<String>(20);
public static LinkedBlockingDeque<String> queue = new LinkedBlockingDeque<String>(20);
public static LinkedBlockingQueue<String> queue = new LinkedBlockingQueue<String>(20);
public static Queue<String> queue =new LinkedList<String>();
public static ConcurrentLinkedQueue<String> queue = new ConcurrentLinkedQueue<String>();
*/
public static ArrayBlockingQueue<String> queue = new ArrayBlockingQueue<String>(20);
public static int size = 15;
public static void main(String[] args) {
Thread t1 = new InnerThread("t1");
Thread t2 = new InnerThread("t2");
t1.start();
t2.start();
try {
Thread.sleep(2000);
printQueue(queue);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
static class InnerThread extends Thread {
String name;
public InnerThread(String name) {
super(name);
this.name=name;
}
@Override
public void run() {
for (int i = 0; i < size; i++) {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
String tmp=i+" "+name;
//queue.add(tmp);
try {
queue.put(tmp);
//queue.add(tmp);
} catch (InterruptedException e) {
log.error("error",e);
}
printQueueNone(queue);
}
}
}
public static void printQueue(Queue queue) {
Iterator iterator = queue.iterator();
while (iterator.hasNext()) {
log.info("thread {} print {}", Thread.currentThread().getName(), iterator.next());
}
}
public static void printQueueNone(Queue queue) {
Iterator iterator = queue.iterator();
while (iterator.hasNext()) {
iterator.next();
}
}
}
运行结果
2019-08-28 19:42:32,684 [main] INFO BlockingQueueTest - thread main print 0 t1
2019-08-28 19:42:32,686 [main] INFO BlockingQueueTest - thread main print 0 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 1 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 1 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 2 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 2 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 3 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 3 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 4 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 4 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 5 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 5 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 6 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 6 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 7 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 7 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 8 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 8 t1
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 9 t2
2019-08-28 19:42:32,687 [main] INFO BlockingQueueTest - thread main print 9 t1
java并发队列的更多相关文章
- 解读 java 并发队列 BlockingQueue
点击添加图片描述(最多60个字)编辑 今天呢!灯塔君跟大家讲: 解读 java 并发队列 BlockingQueue 最近得空,想写篇文章好好说说 java 线程池问题,我相信很多人都一知半解的,包括 ...
- 10分钟搞定 Java 并发队列好吗?好的
| 好看请赞,养成习惯 你有一个思想,我有一个思想,我们交换后,一个人就有两个思想 If you can NOT explain it simply, you do NOT understand it ...
- Java并发队列与容器
[前言:无论是大数据从业人员还是Java从业人员,掌握Java高并发和多线程是必备技能之一.本文主要阐述Java并发包下的阻塞队列和并发容器,其实研读过大数据相关技术如Spark.Storm等源码的, ...
- 并发编程(九)—— Java 并发队列 BlockingQueue 实现之 LinkedBlockingQueue 源码分析
LinkedBlockingQueue 在看源码之前,通过查询API发现对LinkedBlockingQueue特点的简单介绍: 1.LinkedBlockingQueue是一个由链表实现的有界队列阻 ...
- Java 并发队列 BlockingQueue
BlockingQueue 开篇先介绍下 BlockingQueue 这个接口的规则,后面再看其实现. 首先,最基本的来说, BlockingQueue 是一个先进先出的队列(Queue),为什么说是 ...
- 并发编程(八)—— Java 并发队列 BlockingQueue 实现之 ArrayBlockingQueue 源码分析
开篇先介绍下 BlockingQueue 这个接口的规则,后面再看其实现. 阻塞队列概要 阻塞队列与我们平常接触的普通队列(LinkedList或ArrayList等)的最大不同点,在于阻塞队列的阻塞 ...
- 并发编程(十)—— Java 并发队列 BlockingQueue 实现之 SynchronousQueue源码分析
BlockingQueue 实现之 SynchronousQueue SynchronousQueue是一个没有数据缓冲的BlockingQueue,生产者线程对其的插入操作put必须等待消费者的移除 ...
- Java并发(十八):阻塞队列BlockingQueue
阻塞队列(BlockingQueue)是一个支持两个附加操作的队列. 这两个附加的操作是:在队列为空时,获取元素的线程会等待队列变为非空.当队列满时,存储元素的线程会等待队列可用. 阻塞队列常用于生产 ...
- Java并发指南11:解读 Java 阻塞队列 BlockingQueue
解读 Java 并发队列 BlockingQueue 转自:https://javadoop.com/post/java-concurrent-queue 最近得空,想写篇文章好好说说 java 线程 ...
随机推荐
- centos7一步一步搭建docker tomcat 及重点讲解
系统环境:centos7.7 (VMware中) image版本:tomcat:8-jdk8-openjdk (截止2020.01.10该系列版本) 安装步骤参考文章:https://www.jian ...
- python正则表达式中括号的作用,形如 "(\w+)\s+\w+"
先看一个例子: import re string="abcdefg acbdgef abcdgfe cadbgfe" #带括号与不带括号的区别 regex=re.compile(& ...
- C语言:利用指针解决:统计一个长度为2的字符串在另外一个字符串中出现的次数。
//统计一个长度为2的字符串在另外一个字符串中出现的次数. #include <conio.h> #include <stdio.h> #include <string. ...
- Win Oracle 监听文件配置参考
Win lister.ora配置参考 # listener.ora Network Configuration File: C:\app\Administrator\product\\dbhome_1 ...
- 理解CART决策树
CART算法 原理 CART全称为Classification and Regression Tree. 回归树 相比ID3,CART遍历所有的特征和特征值,然后使用二元切分法划分数据子集,也就是每个 ...
- C# MD5加密-MD5Helper
原文地址:https://ken.io/note/csharp-md5 一.前言 MD5说明http://zh.wikipedia.org/wiki/MD5 .NET MD5类 官方文档&示例 ...
- web渗透(转)
某天比较无聊,听一个朋友推荐httpscan这款工具,于是就下载下来试试. 首先对某学校网段开始进行测试. 1 python httpscan.py **.**.**.0/24 测试时发现有个比较 ...
- spring web 测试用例
spring web 测试有三种方式 1. 自己初始化 MockMvc 2.依赖@springbootTest 它会帮你生产 webTestClient ,只需自己注入即可. 3.启动的时候,不加载整 ...
- WLC-WLC升级(以2504为例)
1.WLC升级需要按照升级路径来操作,低版本到高版本的跨度太大,往往需要升级到中间版本,有时候还涉及到FUS. 2.我们升级,一般使用的笔记本上运行的TFTP/FTP server. 需要注意:笔记 ...
- opencv人脸识别提取手机相册内人物充当数据集,身份识别学习(草稿)
未写完 采用C++,opencv+opencv contrib 4.1.0 对手机相册内人物opencv人脸识别,身份识别学习 最近事情多,介绍就先不介绍了 photocut.c #include & ...