`

并发库学习笔记二

    博客分类:
  • java
阅读更多

阻塞队列(生产者和消费者开发模式)

三种常用的阻塞队

ArrayBlockingQueue<T>;

LinkedBlockingQueue<T>;

SynchronousQueue<T>

 

//在队列满时被阻塞

ArrayBlockingQueue<String>arrayBlockingQueue=newArrayBlockingQueue<String>(19);

try{

arrayBlockingQueue.put("");

}catch(InterruptedExceptione){

e.printStackTrace();

}

 

 

 

//如果队列为空则阻塞

ArrayBlockingQueue<String>arrayBlockingQueue=newArrayBlockingQueue<String>(19);

try{

arrayBlockingQueue.take();

}catch(InterruptedExceptione){

e.printStackTrace();

}

 

使用阻塞队列

 

executorService=Executors.newSingleThreadExecutor();

 

 

TaskWithResulttaskWithResult=newTaskWithResult();

Future<String>future=executorService.submit(taskWithResult);

try{

future.get();

 

}catch(InterruptedExceptione){

e.printStackTrace();

}catch(ExecutionExceptione){

e.printStackTrace();

}

finalArrayBlockingQueue<String>arrayBlockingQueue=newArrayBlockingQueue<String>(19);

try{

arrayBlockingQueue.take();

}catch(InterruptedExceptione){

e.printStackTrace();

}

 

classTaskWithResultimplementsCallable<String>{

 

@Override

publicStringcall()throwsException{

//不等待就直接返回

Stringresu=arrayBlockingQueue.poll();

//正确的方法应该是,等待到有数据才继续

Stringresu=arrayBlockingQueue.take();

//防止列等

Stringresu=arrayBlockingQueue.poll(1,TimeUtil.DAY);

 

returnresu;

}

 

}

 

 

//实现一个简单的阻塞队列

classBlockingQ{

privateObjectnoEmpty=newObject();

privateQueue<Object>linkedList=newLinkedList<Object>();

 

publicObjecttake()throwsInterruptedException{

synchronized(noEmpty){

if(linkedList.size()==0){

//要执行wait()操作,必须先得取得对象的锁

//执行wait()操作后,锁会释放

noEmpty.wait();

}

returnlinkedList.poll();

}

}

 

publicvoidoffer(Objectobject){

synchronized(noEmpty){

if(linkedList.size()==0){

//都必须取得对象的锁

noEmpty.notifyAll();

}

linkedList.add(object);

}

}

}

//实现一个简单的阻塞队列2

classBlockingQ{

privateObjectnoEmpty=newObject();

privateObjectnoFull=newObject();

privateQueue<Object>linkedList=newLinkedList<Object>();

privateintmaxLength=10;

 

publicObjecttake()throwsInterruptedException{

synchronized(noEmpty){

if(linkedList.size()==0){

noEmpty.wait();

}

synchronized(noFull){

//如果队列满

if(linkedList.size()==maxLength){

linkedList.notifyAll();

}

returnlinkedList.poll();

}

}

}

 

publicvoidoffer(Objectobject)throwsInterruptedException{

synchronized(noEmpty){

if(linkedList.size()==0){

//都必须取得对象的锁

noEmpty.notifyAll();

}

synchronized(noFull){

//如果队列满

if(linkedList.size()==maxLength){

noFull.wait();

}

}

linkedList.add(object);

}

}

}

 

 

//实现一个简单的阻塞队列3

classBlockingQ{

privateLocklock=newReentrantLock();

//一个锁可以创建多个condition

privateConditionnoEmpty=lock.newCondition();

privateConditionnoFull=lock.newCondition();

privateQueue<Object>linkedList=newLinkedList<Object>();

privateintmaxLength=10;

 

publicObjecttake()throwsInterruptedException{

lock.lock();

try{

if(linkedList.size()==0){

noEmpty.await();

}

//如果队列满

if(linkedList.size()==maxLength){

noFull.signalAll();

}

returnlinkedList.poll();

}finally{

lock.unlock();

}

}

 

publicvoidoffer(Objectobject)throwsInterruptedException{

lock.lock();

try{

if(linkedList.size()==0){

//要执行signal都必须取得对象的锁

noEmpty.signalAll();

}

//如果队列满

if(linkedList.size()==maxLength){

noFull.await();

}

linkedList.add(object);

}finally{

lock.unlock();

}

}

}

注:如果未锁就直接执行awaitsignalsiganlAll会抛异常

 

 

分享到:
评论

相关推荐

    Linux线程开发C++并发库学习笔记

    Linux线程开发C++并发库学习笔记

    java并发库学习笔记

    Java并发库是Java平台中的核心组件,它为多线程编程提供了丰富的工具和接口,使得开发者能够高效、安全地实现并发程序。在Java并发库中,ExecutorService接口和相关的线程池是其核心部分,它们提供了线程管理和任务...

    TBB并发容器 学习笔记

    TBB(Thread Building Blocks)是Intel开发的一个开源C++模板库,专为并行编程设计,旨在帮助开发者充分利用多核处理器的性能。TBB的主要目标是简化并行编程,提供高效、灵活的工具,使程序员可以更容易地创建可扩展...

    JUC并发编程学习笔记(硅谷)

    "JUC并发编程学习笔记(硅谷)"很可能包含了关于Java并发工具集(Java Util Concurrency, JUC)的深入理解和实战经验。JUC是Java标准库提供的一套强大的并发处理工具,它极大地简化了多线程编程,提高了程序的可读性...

    笔记_张孝祥_Java多线程与并发库高级应用

    张孝祥Java多线程与并发库高级应用学习笔记,很经典的学习多线程和并发的资料。张孝祥Java多线程讲义笔记由张孝祥亲自整理,很实用的。

    Go 学习笔记 高清

    总结来说,这份学习笔记为学习Go语言的读者提供了一个详尽的路线图,从基础语法、函数、数据结构到并发编程,再到深入理解标准库和高级特性,循序渐进地指导读者掌握Go语言。这些知识点对于想要深入学习Go语言的...

    Go语言学习笔记.pdf 共174页

    Go语言学习笔记.pdf 共174页是一本关于Go语言的详细学习笔记,涵盖了Go语言的基础知识、函数、数组、Maps、Structs、接口、并发、程序结构、标准库等方面的内容。本笔记共分为三大部分:Go语言基础、标准库和扩展库...

    张孝祥Java多线程与并发库高级应用笔记

    ### 张孝祥Java多线程与并发库高级应用笔记概览 #### 一、Java多线程技术的重要性与挑战 Java线程技术是软件工程领域不可或缺的一部分,尤其在底层编程、Android应用开发以及游戏开发中,其重要性不言而喻。然而,...

    GoLang学习资源_学习笔记和并发编程实战

    "Go语言学习笔记-(详细书签)"是由雨痕编著的,这是一本详实的学习指南,包含了Go语言的基础语法、类型系统、接口、反射、错误处理以及标准库的使用等内容。书签的设置使得你可以快速定位到感兴趣的主题,无论是初学...

    Go语言学习笔记.pdf

    为了深入了解Go语言,学习笔记通常包含语言的基本概念、语法特性、开发环境配置及核心功能的使用方法。 首先,Go语言相较于C++等传统编程语言,有一些显著的特征区别。Go语言为了简化设计,不支持函数重载和操作符...

    VHDL语言学习笔记

    本学习笔记将深入探讨VHDL的基础概念、语法特性以及在实际设计中的应用。 1. **VHDL的基本结构** VHDL的结构主要包括实体(Entity)、架构(Architecture)、包(Package)和配置(Configuration)。实体描述了...

    Go 学习笔记 第四版 pdf

    根据提供的信息,我们可以总结出这份文档是关于Go语言学习笔记的部分内容,主要涵盖了Go语言的基础概念、语法结构、数据类型以及并发模型等关键知识点。以下是对这些知识点的详细解析: ### Go语言概述 Go(也称作...

    Java学习笔记——良葛格

    "Java学习笔记——良葛格"是一份专为初学者设计的教程资料,由良葛格精心编写,旨在帮助读者掌握JDK5.0版本的Java基础知识。JDK(Java Development Kit)是Java开发的核心工具集,包含了编译器、调试器和运行环境等...

    Go学习笔记-第四版-雨痕

    《Go学习笔记-第四版》是由知名编程作者雨痕编写的关于Go语言的教程,旨在帮助读者深入理解和掌握Go语言的各个方面。Go语言,又称Golang,是Google于2009年推出的一种静态类型的、编译型的、并发型且具有垃圾回收...

    Java入门学习笔记

    "Java入门第二季学习笔记"可能深入到更复杂的主题,如异常处理、集合框架、IO流和线程。异常处理是Java中处理错误的重要机制,使得程序更加健壮。集合框架包括ArrayList、LinkedList、HashSet、HashMap等数据结构,...

    Go语言学习笔记

    Go语言学习笔记的知识点涵盖广泛,它从基础的语法到高级的并发编程,再到源码的剖析,全面介绍了Go语言的特点和编程技巧。以下是根据所提供的文件内容提取的知识点: 1. Go语言基础:Go是一种静态类型编程语言,...

    多线程学习笔记

    多线程学习笔记 iOS开发中,多线程是一种常见的技术手段,用于优化应用程序的性能,提升用户体验。多线程的核心是让程序能够并发地执行多个任务,合理地利用设备的计算能力,尤其是在拥有多个核心的处理器上。 ...

    牛【SystemVerilog】路科验证V2学习笔记(全600页)

    "牛【SystemVerilog】路科验证V2学习笔记(全600页)"是一份详尽的学习资料,涵盖了路科验证方法论的第二版(V2)在SystemVerilog中的应用。 笔记内容可能包含了以下几个关键知识点: 1. **基础语法**:...

Global site tag (gtag.js) - Google Analytics