notifyAll()_notify for

notifyAll()_notify for下面这段代码suclassCalculaterextendsThread{ publicinttotal=1; publicvoidrun(){ System.out.println(“Calculatorrun”); synchronized(this){ for(inti=1;i<10;i++){ total*=i; }

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

下面这段代码说明了, notifyAll将所有等待在Calculater对象cal的对象锁上的所有线程从阻塞状态变为可运行状态, 但是他们要获得cal对象锁才能继续执行, 随意他们会按随机顺序一个一个的执行完剩下的代码。

class Calculater extends Thread{
	public int total = 1;
	public void run(){
		System.out.println("Calculator run");
		synchronized(this){
			for(int i=1; i<10; i++){
				total *= i;
			}
			notifyAll();
		}
	}
}

public class NotifyAllTest extends Thread{
	public Calculater cal;
	public NotifyAllTest(Calculater cal){
		this.cal = cal;
	}
	public void run(){
		System.out.println(this.currentThread()+" runing ");
		synchronized(this.cal){
			try {
				this.cal.wait();
				System.out.println(this.currentThread() + "wake up");
			} catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
			System.out.println(this.currentThread()+" : total = "+this.cal.total);
			try {
				Thread.sleep(1000);
			} catch (InterruptedException e) {
				// TODO Auto-generated catch block
				e.printStackTrace();
			}
		}
	}
	public static void main(String [] args) throws InterruptedException{
		Calculater cal = new Calculater();
		new NotifyAllTest(cal).start();
		new NotifyAllTest(cal).start();
		new NotifyAllTest(cal).start();
		new NotifyAllTest(cal).start();
		new NotifyAllTest(cal).start();
		Thread.sleep(1000);
		cal.start();
	}

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/197761.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • msfconsole安装命令_msfconsole实战

    msfconsole安装命令_msfconsole实战使用curlhttps://raw.githubusercontent.com/rapid7/metasploit-omnibus/master/config/templates/metasploit-framework-wrappers/msfupdate.erb>msfinstall&&\chmod755msfinstall&&\./msfinstall安

    2025年9月23日
    4
  • java volatile原理

    java volatile原理一、基本概念先补充一下概念:Java内存模型中的可见性、原子性和有序性。可见性:  可见性是一种复杂的属性,因为可见性中的错误总是会违背我们的直觉。通常,我们无法确保执行读操作的线程能适时地看到其他线程写入的值,有时甚至是根本不可能的事情。为了确保多个线程之间对内存写入操作的可见性,必须使用同步机制。  可见性,是指线程之间的可见性,一个线程修改的状态对另一个线程是可见的。也就是…

    2022年7月18日
    14
  • PriorityQueue源码分析

    PriorityQueue源码分析来源:Java编程的逻辑1前导将新的头部与两个孩子节点中较小的比较,如果不大于该孩子节点,则满足堆的性质,结束,否则与较小的孩子进行交换,交换后,再与较小的孩子比较和交换,一直到没有孩子,或者不大于两个孩子节点。这个过程我们般称为siftdown与父节点比较,如果大于等于父节点,则满足堆的性质,结束,否则与父节点进行交换,然后再与父节点比较和交换,直到父节点为空或者大于等于父节点;称之为…

    2022年6月8日
    31
  • X-Router软路由设置

    X-Router软路由设置

    2021年11月17日
    43
  • fetch_array()与fetch_assoc()的用法

    fetch_array()与fetch_assoc()的用法

    2021年11月4日
    44
  • 图论——握手定理_离散数学 树 握手定理

    图论——握手定理_离散数学 树 握手定理这是一个非常重要的图论定理在多出用到:握手定理:在任何有向图图中,所有顶点的度数之和等于边数的2倍,所有顶点的入度之和等于所有顶点出度之和,等于边数无向简单图,同样所有顶点的度数之和等于边数的2

    2022年8月5日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号