`

JAVA多线程编程实践

 
阅读更多

 

1.闭锁

  闭锁(latch)是一种Synchronizer,它可以延迟线程的进度直到线程打到终止状态。一个闭锁工作起来就像一道大门:直到闭锁达到终点状态之前,门一直是关着的,没有线程能够通过,在终点状态到来的时候,门开了,允许所有线程通过。一旦闭锁达到了终点状态,它就不能改变状态了,所以它会永远保持敞开状态。闭锁可以用来确保特定活动直道其他活动完成后发生。(引用 java并发编程实践)

 

2.CountDownLatch

  CountDownLatch是一个灵活的闭锁的实现,允许一个任务等待其他任务执行完毕后才能执行,闭锁的状态包括一个计数器,用来表现需要等待的任务数。countDown方法对计数器做减操作,表示一个事件的已经发生,而await方法等待计数器打到零,此时所有需要等待的事件都已经发生,如果计数器入口值为非零,await会一直阻塞到计数器为零,或者等待线程中断或超时。

 

import java.util.Random;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;


public class DemoCDL {
	public static void main(String[] args) {
		ExecutorService service = Executors.newCachedThreadPool();
		CountDownLatch downLatch = new CountDownLatch(3);
		Student s1 = new Student(downLatch, "no1");
		Student s2 = new Student(downLatch, "no2");
		Student s3 = new Student(downLatch, "no3");
		Teacher t = new Teacher(downLatch);
		
		service.execute(t);
		service.execute(s1);
		service.execute(s2);
		service.execute(s3);
	}
}

class Teacher implements Runnable{
	private CountDownLatch downLatch;

	public Teacher(CountDownLatch downLatch) {
		this.downLatch = downLatch;
	}

	@Override
	public void run() {
		System.out.println("老师等待学生全部交完试卷");
		try {
			downLatch.await();
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		System.out.println("所有学生交完试卷,考试结束");
	}
}

class Student implements Runnable{

	private CountDownLatch downLatch;
	private String name;

	public Student(CountDownLatch downLatch, String name) {
		this.downLatch = downLatch;
		this.name = name;
	}

	@Override
	public void run() {
		System.out.println(name + " 开始答卷");
		try {
			TimeUnit.SECONDS.sleep(new Random().nextInt(10)); //假设学生在随机数内就答完卷
			System.out.println(name + "答完卷上交试卷");
			downLatch.countDown();
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
}

 

    执行结果:

老师等待学生全部交完试卷
no1 开始答卷
no2 开始答卷
no3 开始答卷
no1答完卷上交试卷
no2答完卷上交试卷
no3答完卷上交试卷
所有学生交完试卷,考试结束

 

 
3.CyclicBarrier

       CyclicBarrier与CountDownLatch相似,jdk解释A synchronization aid that allows a set of threads to all wait for each other to reach a common barrier point.意思可以实现让一组线程等待至某个状态之后在全部同时执行。

       CyclicBarrier的2个构造函数:

       CyclicBarrier(int parties);

       CyclicBarrier(int parties, Runnable barrierAction);barrierAction即为当这些线程都达到barrier状态时会执行的内容。

 

 

import java.util.Random;
import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.CyclicBarrier;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;

public class DemoCB {

	public static void main(String[] args) {
		CyclicBarrier cyclicBarrier = new CyclicBarrier(3, new Runnable(){
			@Override
			public void run() {
				System.out.println("在所有线程达到barrier状态执行内容");
			}
		});
		
		ExecutorService service = Executors.newCachedThreadPool();
		Worker w1 = new Worker(cyclicBarrier, "w1");
		Worker w2 = new Worker(cyclicBarrier, "w2");
		Worker w3 = new Worker(cyclicBarrier, "w3");
		service.execute(w1);
		service.execute(w2);
		service.execute(w3);
	}
}

class Worker implements Runnable{

	private CyclicBarrier cyclicBarrier;
	private String name;
	
	public Worker(CyclicBarrier cyclicBarrier, String name) {
		this.cyclicBarrier = cyclicBarrier;
		this.name = name;
	}

	@Override
	public void run() {
		try {
			System.out.println(name +"  等待执行");
			TimeUnit.SECONDS.sleep(new Random().nextInt(10));
			//等待所有线程打到barrier状态
			cyclicBarrier.await();
			System.out.println(name + " 开始工作");
		} catch (InterruptedException | BrokenBarrierException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

 执行结果

w2  等待执行
w1  等待执行
w3  等待执行
在所有线程达到barrier状态执行内容
w1 开始工作
w3 开始工作
w2 开始工作

 

 

 

分享到:
评论

相关推荐

    java 多线程编程实战指南(核心 + 设计模式 完整版)

    《Java多线程编程实战指南》这本书深入浅出地讲解了Java多线程的核心概念和实战技巧,分为核心篇和设计模式篇,旨在帮助开发者掌握并应用多线程技术。 1. **线程基础** - **线程的创建**:Java提供了两种创建线程...

    Java多线程编程核心技术_完整版_java_

    Java多线程编程是Java开发中的...以上内容只是《Java多线程编程核心技术》教程中的一部分核心知识点,实际学习中还需要结合具体示例和实践来深入理解和掌握。通过学习,开发者可以编写出高效、稳定的多线程Java程序。

    Java多线程编程实战指南-核心篇

    《Java多线程编程实战指南-核心篇》是一本深入探讨Java并发编程的书籍,旨在帮助读者掌握在Java环境中创建、管理和同步线程的核心技术。Java的多线程能力是其强大之处,使得开发者能够在同一时间执行多个任务,提高...

    深入学习:Java多线程编程

    《深入学习:Java多线程编程》是一本专注于Java并发技术的专业书籍,旨在帮助开发者深入理解和熟练运用Java中的多线程编程。Java多线程是Java编程中的核心部分,尤其在现代高性能应用和分布式系统中不可或缺。理解并...

    java 多线程编程指南

    总之,“Java多线程编程指南”将涵盖这些核心概念,并可能深入到高级话题,如线程池的优化、并发容器的使用以及并发编程的最佳实践,帮助读者提升在多线程环境下的编程能力。通过深入学习和实践,开发者能够构建出...

    Java多线程与线程安全编程实践-基于Http协议的断点续传.zip

    Java多线程与线程安全编程实践-基于Http协议的断点续传.zip Java多线程与线程安全编程实践-基于Http协议的断点续传.zip Java多线程与线程安全编程实践-基于Http协议的断点续传.zip Java多线程与线程安全编程实践-...

    java多线程编程

    Java多线程编程是Java开发中的重要组成部分,它允许程序同时执行多个任务,提升系统效率。在本教程中,我们将深入探讨Java中的多线程设计模式、并发核心编程概念以及线程池的工作原理和种类。 首先,让我们了解什么...

    java多线程编程实例

    从给定的文件信息中,我们可以提取出关于Java多线程编程的重要知识点,涉及线程创建、线程生命周期以及线程间的同步与通信等核心概念。...通过实际操作和不断实践,可以更深入地掌握Java多线程编程的精髓。

    Java多线程编程核心技术.zip

    本资料"Java多线程编程核心技术.zip"深入探讨了这些核心技术,并提供了源码供学习者实践和理解。 1. **线程的创建与启动** - 继承Thread类:自定义类继承Thread类,重写run()方法,然后创建该类对象并调用start()...

    《Java多线程编程实例》随书源码

    通过《Java多线程编程实例》随书源码,读者可以深入了解并实践这些概念,例如创建和管理线程池、实现线程安全的数据结构、解决死锁问题以及优化多线程应用等。书中的实例涵盖了多线程编程的各个重要方面,对于提升...

    java多线程编程实例 (源程序)

    通过学习和实践这些Java多线程编程的知识点,开发者可以创建高效、健壮的多线程应用程序。提供的源程序文件可以作为学习和调试的实例,帮助你更好地理解和掌握这些概念。在实际开发中,理解并熟练运用这些技术,能...

    java多线程的讲解和实战

    Java多线程是Java编程中的重要概念,尤其在如今的多核处理器环境下,理解并熟练掌握多线程技术对于提高程序性能和响应速度至关重要...通过对这些知识点的学习和实践,读者可以深入理解Java多线程的运用,提升编程技能。

    基于Http协议的断点续传-Java多线程与线程安全实践编程.zip

    基于Http协议的断点续传-Java多线程与线程安全实践编程.zip 基于Http协议的断点续传-Java多线程与线程安全实践编程.zip 基于Http协议的断点续传-Java多线程与线程安全实践编程.zip 基于Http协议的断点续传-Java多...

    Java多线程编程详解

    ### Java多线程编程详解:深入理解与实践 #### 一、理解多线程机制 多线程,作为现代编程语言的重要特性之一,允许在单一应用程序内并发执行多个任务,从而极大提升了程序的效率和响应速度。在Java中,多线程的...

    Java多线程编程深入详解.docx

    Java多线程编程深入详解 多线程编程是Java编程语言中的一种...Java多线程编程是一种强大而复杂的技术,需要深入理解和实践。通过本文,我们了解了多线程编程的基础知识和高级技术,掌握了多线程编程的要领和实践经验。

    java多线程编程(第二版)

    Java多线程编程是Java开发中的重要组成部分,尤其在当今并发处理需求日益增长的时代,对多线程的理解和掌握显得尤为重要。《Java多线程编程(第二版)》这本书深入探讨了这一主题,旨在帮助开发者更好地理解和应用...

    Java多线程编程实战指南 设计模式篇.rar

    在Java编程中,多线程是一项关键技能,它允许程序同时执行多个任务,极大地提高了程序的...通过阅读"Java多线程编程实战指南 设计模式篇.pdf",你将获得更深入的理论知识和实践技巧,为你的编程事业奠定坚实的基础。

    Java多线程练习题

    Java多线程是Java编程中的核心概念,它允许程序同时执行多个任务,提高了系统的效率和响应性。在Java中,多线程的实现主要通过两种方式:继承Thread类和实现Runnable接口。理解并掌握多线程的使用对于任何Java开发者...

    java多线程编程实例_Source

    Java多线程编程是Java开发中的...每个章节的源码都是一个独立的案例,可以逐一研究,实践和调试,以便更好地掌握Java多线程编程技巧。在学习过程中,结合理论知识与实际操作,将有助于提升对Java并发编程的全面认识。

    Java多线程编程实战指南(设计模式篇)

    《Java多线程编程实战指南(设计模式篇)》由黄文海撰写,是一本深入探讨Java多线程编程和设计模式的专业书籍。书中详细介绍了如何在Java环境中利用多线程来实现高效的并发处理,同时结合设计模式,帮助开发者更好地...

Global site tag (gtag.js) - Google Analytics