`
alchimie
  • 浏览: 20903 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

[Java并发编程实战] 读书笔记(1):闭锁

 
阅读更多

闭锁(Latch)

闭锁(Latch):一种同步工具类,可以延迟线程的进度直到其到达终止状态。其作用相当于一扇门,这扇门打开之前,所有线程的将被阻塞在门前,只有在门打开后,所有的线程才能通过。并且门(闭锁)的状态是一次性的(栅栏则是可控),只要门一打开,就不能再关闭。闭锁可以用来确保某些活动直到其它活动都完成后才继续执行。

 

CountDownLatch是java.util.concurrent包里关于闭锁的一种实现,其API如下: 

public CountDownLatch(int count)

// 使当前线程在锁存器倒计数至零之前一直等待,除非线程被中断

public void await() throws InterruptedException

// 使当前线程在锁存器倒计数至零之前一直等待,除非线程被 中断或超出了指定的等待时间。 

public boolean await(long timeout, TimeUnit unit) throws InterruptedException

// 倒计数

public void countDown()

// 返回当前计数

public long getCount() 

 

上代码(JCIP5-5加上注释和main()):

 

/**
 * TestHarness Using CountDownLatch for starting and stopping threads in timing
 * tests
 * 
 * @author Brian Goetz and Tim Peierls
 * @author Modified by alchimie
 */
public class TestHarness {
	public long timeTasks(int nThreads, final Runnable task)
			throws InterruptedException {
		// 起始门
		final CountDownLatch startGate = new CountDownLatch(1);
		// 终止门
		final CountDownLatch endGate = new CountDownLatch(nThreads);

		for (int i = 0; i < nThreads; i++) {
			Thread t = new Thread() {
				public void run() {
					try {
						System.out.println("线程"
								+ Thread.currentThread().getName() + "等待执行");
						// 线程等待闭锁打开
						startGate.await();
						try {
							task.run();
						} finally {
							endGate.countDown();
						}
					} catch (InterruptedException ignored) {
					}
				}
			};
			t.start();
		}

		long start = System.nanoTime();
		// 加入一小段等待时间让所有线程就绪
		Thread.sleep(100);
		startGate.countDown();
		System.out.println("线程" + Thread.currentThread().getName() + "等待");
		// 主线程等待所有子线程运行结束
		endGate.await();
		System.out.println("线程" + Thread.currentThread().getName() + "执行");
		long end = System.nanoTime();
		return end - start;
	}

	public static void main(String args[]) {
		TestHarness th = new TestHarness();
		try {
			long time = th.timeTasks(5, new Thread(new Runnable() {
				public void run() {
					System.out.println("线程" + Thread.currentThread().getName()
							+ "执行完毕");
				}
			}));
			System.out.println("统计时间" + time);
		} catch (InterruptedException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}
}

 

 

执行结果:

线程Thread-1等待执行

线程Thread-4等待执行

线程Thread-3等待执行

线程Thread-2等待执行

线程Thread-5等待执行

线程main等待

线程Thread-1执行完毕

线程Thread-5执行完毕

线程Thread-2执行完毕

线程Thread-3执行完毕

线程Thread-4执行完毕

线程main执行

统计时间100455504

 

分享到:
评论

相关推荐

    java并发编程实战源码,java并发编程实战pdf,Java

    《Java并发编程实战》是Java并发编程领域的一本经典著作,它深入浅出地介绍了如何在Java平台上进行高效的多线程编程。这本书的源码提供了丰富的示例,可以帮助读者更好地理解书中的理论知识并将其应用到实际项目中。...

    Java 并发编程实战.pdf

    《Java并发编程实战》这本书是关于Java语言中并发编程技术的经典著作。它详细介绍了如何在Java环境中有效地实现多线程程序和并发控制机制。在Java平台上,由于其本身提供了强大的并发编程支持,因此,掌握并发编程...

    《java 并发编程实战高清PDF版》

    《Java并发编程实战》是一本深入探讨Java平台并发编程的权威指南。这本书旨在帮助开发者理解和掌握在Java环境中创建高效、可扩展且可靠的多线程应用程序的关键技术和实践。它涵盖了从基本概念到高级主题的广泛内容,...

    Java并发编程实战华章专业开发者书库 (Tim Peierls 等 美Brian Goetz).pdf

    《Java并发编程实战》是一本深入探讨Java平台并发编程的权威指南,由Tim Peierls等人与Brian Goetz合著,旨在帮助Java开发者理解和掌握在多线程环境中编写高效、安全的代码。这本书由拥有丰富经验的JDK并发大师及...

    (PDF带目录)《Java 并发编程实战》,java并发实战,并发

    《Java 并发编程实战》是一本专注于Java并发编程的权威指南,对于任何希望深入了解Java多线程和并发控制机制的开发者来说,都是不可或缺的参考资料。这本书深入浅出地介绍了如何在Java环境中有效地管理和控制并发...

    java并发编程实践pdf笔记

    这本书的读书笔记涵盖了多个关键知识点,旨在帮助读者深入理解Java并发编程的核心概念。 1. **线程和进程的区别** - **线程** 是程序执行的最小单位,一个进程中可以有多个线程同时执行,共享同一块内存空间,通信...

    62-Java并发编程实战

    62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java并发编程实战62-Java...

    java并发编程与实践

    3. **并发工具类**:Java并发包(java.util.concurrent)包含了许多工具类,如Semaphore(信号量)、CyclicBarrier(回环屏障)、CountDownLatch(计数器门锁)和ThreadPoolExecutor(线程池)。这些工具可以帮助...

    读书笔记-Java并发编程实战-基础篇

    7. Java内置锁和锁的粒度:Java中的`synchronized`关键字用于实现内置锁,它保证了线程对共享资源的互斥访问。关于锁的粒度,需要根据实际情况来决定是使用细粒度还是粗粒度的锁。使用同步时,需要考虑代码同步块的...

    Java并发编程实战.pptx

    Java并发编程实战需要了解Java中的线程模型、锁机制、线程池、并发集合类等概念和技术,以及如何使用Java中的各种并发编程工具和框架来实现高效、可靠的并发编程。 Java并发编程实战的目标是提高程序的响应速度、...

    Java并发编程实践高清pdf及源码

    2. **同步控制**:Java中的`synchronized`关键字用于控制对共享资源的访问,它可以修饰方法或代码块,确保同一时间只有一个线程能执行特定的代码。此外,`ReentrantLock`类提供了更细粒度的锁控制。 3. **并发容器*...

    Java 并发编程实战(高清带目录).zip

    《Java 并发编程实战》是一本面向Java开发者的深度技术书籍,专注于讲解在多线程环境下如何有效地编写高效、安全的并发代码。这本书高清且带有详细的目录,方便读者快速定位到所需的主题,是Java并发编程领域的重要...

    java并发编程实战源码 附有本书所有源码,maven 导入 eclipse或idea

    除了提供读者全面指南编写并发Java应用程序的书籍“Java Concurrency in Practice”外,还可以下载相关源代码。这包括书中使用的所有源代码示例,可以使用Maven轻松地将其导入Eclipse或IntelliJ IDEA中。通过实践源...

    Java 并发编程实战 中英文+代码示例

    4. **并发集合**:Java并发包中的ConcurrentHashMap、CopyOnWriteArrayList和CopyOnWriteArraySet等集合,它们是线程安全的,适合多线程环境下使用,避免了传统的同步带来的性能开销。 5. **原子变量类**:...

    Java并发编程学习笔记.rar

    这本"Java并发编程学习笔记"可能是作者在深入研究Java并发特性、工具和最佳实践过程中积累的心得体会。下面,我们将根据这个主题,探讨一些关键的Java并发编程知识点。 1. **线程与进程**:在多任务环境中,线程是...

    读书笔记:Java并发编程之美笔记.zip

    读书笔记:Java并发编程之美笔记

    JAVA并发编程实践.pdf+高清版+目录 书籍源码

    《JAVA并发编程实践》这本书是Java开发者深入理解并发编程的重要参考资料。它涵盖了Java并发的核心概念、工具和最佳实践,旨在帮助读者在多线程环境下编写高效、安全的代码。 并发编程是现代软件开发中的关键技能,...

Global site tag (gtag.js) - Google Analytics