java中线程存活和线程执行的问题!

简介:
 1 /*
 2 下面的程序会出现下面的情况,当Thread-0, Thread-1, Thread-2都被wait的时候,可能会同时苏醒
 3     Thread-0 put
 4     Thread-1 put
 5     Thread-2 put
 6     Thread-3 get//在此处,Thread-3拿到锁之后,将所有的等待的线程唤醒,才有了下面的输出
 7     Thread-2 put
 8     Thread-1 put
 9     Thread-0 put
10 */
11 
12 
13    虽然多个线程会同时苏醒,但是只有一个能获得cpu的执行权!
14    总之,同步中执行的只能是一个,但是存活的不一定就是一个!
15 
16 
17 class DuckD{
18     public void put(){
19         
20         synchronized(DuckD.class){
21           
22               System.out.println(Thread.currentThread().getName()+" put");
23               try{
24                  DuckD.class.wait();//Thread-0, Thread-1, Thread-2可能会同时在这里苏醒!
25               }catch(InterruptedException e){
26                  
27               }
28               //........
29         }
30     }
31     
32     public void get(){
33         
34         synchronized(DuckD.class){
35 
36                 DuckD.class.notifyAll();
37               System.out.println(Thread.currentThread().getName()+" get");
38               try{
39                  DuckD.class.wait();
40               }catch(InterruptedException e){
41                  
42               }         
43         }
44     }
45 }
46 
47 class ProduceD implements Runnable{
48     DuckD dk;
49     ProduceD(DuckD dk){
50        this.dk=dk;
51     }
52     public void run(){
53        while(true)
54          dk.put();
55     }    
56 }
57 
58 class ConsumeD implements Runnable{
59     DuckD dk;
60     ConsumeD(DuckD dk){
61        this.dk=dk;
62     }
63     public void run(){
64         while(true)
65           dk.get();
66     }    
67 }
68 
69 class Test{
70    public static void main(String[] args){
71        DuckD dk=new DuckD();
72        Thread t1=new Thread(new ProduceD(dk));
73        Thread t2=new Thread(new ProduceD(dk));
74        Thread t3=new Thread(new ProduceD(dk));
75        Thread t4=new Thread(new ConsumeD(dk));
76        
77        t1.start();
78        t2.start();
79        t3.start();
80        t4.start();
81    }
82 }
复制代码









本文转自 小眼儿 博客园博客,原文链接:http://www.cnblogs.com/hujunzheng/p/3920873.html,如需转载请自行联系原作者
目录
相关文章
|
10天前
|
安全 Java
java 中 i++ 到底是否线程安全?
本文通过实例探讨了 `i++` 在多线程环境下的线程安全性问题。首先,使用 100 个线程分别执行 10000 次 `i++` 操作,发现最终结果小于预期的 1000000,证明 `i++` 是线程不安全的。接着,介绍了两种解决方法:使用 `synchronized` 关键字加锁和使用 `AtomicInteger` 类。其中,`AtomicInteger` 通过 `CAS` 操作实现了高效的线程安全。最后,通过分析字节码和源码,解释了 `i++` 为何线程不安全以及 `AtomicInteger` 如何保证线程安全。
java 中 i++ 到底是否线程安全?
|
1天前
|
安全 Java 测试技术
Java并行流陷阱:为什么指定线程池可能是个坏主意
本文探讨了Java并行流的使用陷阱,尤其是指定线程池的问题。文章分析了并行流的设计思想,指出了指定线程池的弊端,并提供了使用CompletableFuture等替代方案。同时,介绍了Parallel Collector库在处理阻塞任务时的优势和特点。
|
1天前
|
安全 Java 编译器
Java多线程编程的陷阱与最佳实践####
【10月更文挑战第29天】 本文深入探讨了Java多线程编程中的常见陷阱,如竞态条件、死锁、内存一致性错误等,并通过实例分析揭示了这些陷阱的成因。同时,文章也分享了一系列最佳实践,包括使用volatile关键字、原子类、线程安全集合以及并发框架(如java.util.concurrent包下的工具类),帮助开发者有效避免多线程编程中的问题,提升应用的稳定性和性能。 ####
15 1
|
5天前
|
存储 设计模式 分布式计算
Java中的多线程编程:并发与并行的深度解析####
在当今软件开发领域,多线程编程已成为提升应用性能、响应速度及资源利用率的关键手段之一。本文将深入探讨Java平台上的多线程机制,从基础概念到高级应用,全面解析并发与并行编程的核心理念、实现方式及其在实际项目中的应用策略。不同于常规摘要的简洁概述,本文旨在通过详尽的技术剖析,为读者构建一个系统化的多线程知识框架,辅以生动实例,让抽象概念具体化,复杂问题简单化。 ####
|
6天前
|
Java 开发者
在Java多线程编程的世界里,Lock接口正逐渐成为高手们的首选,取代了传统的synchronized关键字
在Java多线程编程的世界里,Lock接口正逐渐成为高手们的首选,取代了传统的synchronized关键字
31 4
|
6天前
|
消息中间件 供应链 Java
掌握Java多线程编程的艺术
【10月更文挑战第29天】 在当今软件开发领域,多线程编程已成为提升应用性能和响应速度的关键手段之一。本文旨在深入探讨Java多线程编程的核心技术、常见问题以及最佳实践,通过实际案例分析,帮助读者理解并掌握如何在Java应用中高效地使用多线程。不同于常规的技术总结,本文将结合作者多年的实践经验,以故事化的方式讲述多线程编程的魅力与挑战,旨在为读者提供一种全新的学习视角。
27 3
|
7天前
|
安全 Java 调度
Java中的多线程编程入门
【10月更文挑战第29天】在Java的世界中,多线程就像是一场精心编排的交响乐。每个线程都是乐团中的一个乐手,他们各自演奏着自己的部分,却又和谐地共同完成整场演出。本文将带你走进Java多线程的世界,让你从零基础到能够编写基本的多线程程序。
19 1
|
13天前
|
监控 安全 Java
在 Java 中使用线程池监控以及动态调整线程池时需要注意什么?
【10月更文挑战第22天】在进行线程池的监控和动态调整时,要综合考虑多方面的因素,谨慎操作,以确保线程池能够高效、稳定地运行,满足业务的需求。
93 38
|
14天前
|
Java 调度
[Java]线程生命周期与线程通信
本文详细探讨了线程生命周期与线程通信。文章首先分析了线程的五个基本状态及其转换过程,结合JDK1.8版本的特点进行了深入讲解。接着,通过多个实例介绍了线程通信的几种实现方式,包括使用`volatile`关键字、`Object`类的`wait()`和`notify()`方法、`CountDownLatch`、`ReentrantLock`结合`Condition`以及`LockSupport`等工具。全文旨在帮助读者理解线程管理的核心概念和技术细节。
31 1
[Java]线程生命周期与线程通信
下一篇
无影云桌面