浅谈线程通信wait,notify作用

 更新时间:2017年12月25日 15:59:33   作者:乐小小98  
这篇文章主要介绍了浅谈线程通信wait,notify作用,具有一定借鉴价值,需要的朋友可以参考下

线程通信的目的是为了能够让线程之间相互发送信号。另外,线程通信还能够使得线程等待其它线程的信号,比如,线程B可以等待线程A的信号,这个信号可以是线程A已经处理完成的信号

Wait()方法

-中断方法的执行,使本线程等待,暂时让出cpu的使用权,并允许其他线程使用这个同步方法

Notify()方法

-唤醒由于使用这个同步方而处于等待线程的某一个结束等待

Notifyall()方法

唤醒所有由于使用这个同步方法而处于等待的线程结束等待

什么时候使用wait方法

当一个线程使用的同步方法中用到某个变量,而此变量又需要其他线程修改才能符合本线程的需要,那么可以在同步方法中使用wait()方法

在这里我以课上的一个例子为例,简述一下wait和notify的作用

我们已经知道开启多线程中,如卖票,每个窗口卖的票的顺序是随机的,如果我们有2个卖票窗口,规定100张票必须轮流卖,A窗口卖完一张票之后下一张票一定是由B窗口卖的,我们如何实现这个功能?

首先我想的是可以设置一个if语句,if(i%2==0)则线程1运行,否则则线程2运行,但是线程1和线程2的运行是随机的,不能规定由i的大小来确定谁运行

那我们可以用线程中的wait()和notify()

线程1运行完之后等待一下,然后线程2运行,线程2运行完之后再唤醒线程1然后再次

线程1运行完之后等待一下,然后线程2运行,线程2运行完之后再唤醒线程1

这样的话可以轮流运行线程1和线程2

我们已打印10个数为例子来编写程序,一共建2个类Myprint和MyprintTest

Myprint.java

public class Myprint implements Runnable { 
private int i=0;
@Override 
public void run() {
	try {
		print();
	}
	catch (InterruptedException e) {
		// TODO Auto-generated catch block 
		e.printStackTrace();
	}
}
public synchronized void  print() throws InterruptedException{
	while(i<10){
		System.out.println(Thread.currentThread().getName()+":"+i);
		i++;
		notify();
		try {
			wait();
		}
		catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
}
}

结果如图

可以看到已经实现了线程1和线程2相互交替打印

只需理解运行过程即可

while(i<10){
	System.out.println(Thread.currentThread().getName()+":"+i);
	i++;
	notify();
	try {
		wait();
	}
	catch (InterruptedException e) {
		e.printStackTrace();
	}
}
}
}

当i<10时,打印线程1,然后执行唤醒,由于前面没有线程所以这一步不执行,然后线程1等待,执行完线程2唤醒前面的线程即线程1,然后打印线程1,

这个过程一直执行下去直到跳出循环,所以我们可以实现轮流运行

总结

以上就是本文关于浅谈线程通信wait,notify作用的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!

相关文章

  • Spring Security的简单使用

    Spring Security的简单使用

    这篇文章主要介绍了Spring Security的简单使用,帮助大家更好的理解和学习使用SpringBoot,感兴趣的朋友可以了解下
    2021-04-04
  • Spring 异步接口返回结果的四种方式

    Spring 异步接口返回结果的四种方式

    这篇文章主要介绍了Spring 异步接口返回结果的四种方式,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的小伙伴可以参考一下
    2022-08-08
  • java Unsafe详细解析

    java Unsafe详细解析

    Unsafe为我们提供了访问底层的机制,这种机制仅供java核心类库使用,而不应该被普通用户使用。但是,为了更好地了解java的生态体系,我们应该去学习它,去了解它,不求深入到底层的C/C++代码,但求能了解它的基本功能。下面小编来和大家一起学习
    2019-05-05
  • MyBatis一对一映射初识教程

    MyBatis一对一映射初识教程

    MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架。在我们生活中一对一的例子很多见,下面通过本文给大家带来了mybatis一对一映射初识教程,感兴趣的朋友一起看下吧
    2016-08-08
  • MyBatis多数据源的两种配置方式

    MyBatis多数据源的两种配置方式

    这篇文章主要给大家介绍了关于MyBatis多数据源的两种配置方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-12-12
  • Java服务端性能优化之JVM垃圾回收策略详解

    Java服务端性能优化之JVM垃圾回收策略详解

    JVM垃圾回收策略涵盖了基本原理、常见策略(如SerialGC、ParallelGC、CMS、G1GC)以及优化建议,选择合适的策略和调整参数,如堆大小和GC日志,可以提高应用性能和响应速度,持续监控和分析是关键步骤
    2025-03-03
  • Java中的Object类详细解读

    Java中的Object类详细解读

    这篇文章主要介绍了Java中的Object类详细解读,java.lang.Object是类层次结构的根类,即所有其它类的父类,每个类都使用 Object 作为超类,需要的朋友可以参考下
    2023-11-11
  • JavaWeb中的文件的上传和下载

    JavaWeb中的文件的上传和下载

    JavaWeb 文件的上传和下载是指在Web应用中实现用户上传文件到服务器和从服务器下载文件的功能,通过JavaWeb技术,可以方便地实现文件的上传和下载操作,提供更好的用户体验和数据交互,需要的朋友可以参考下
    2023-10-10
  • Java volatile关键字特性讲解上篇

    Java volatile关键字特性讲解上篇

    JMM要求保证可见性、原子性、有序性,volatile可以保证其中的两个,本篇文章具体验证volatile的可见性,不原子性和禁重排,同时解决volatile的不保证原子性,让代码具有原子性
    2022-12-12
  • Spring Cloud原理以及核心组件详解

    Spring Cloud原理以及核心组件详解

    这篇文章主要介绍了Spring Cloud原理以及核心组件详解,spring cloud有5个核心组件,文章中进行了一一的详细介绍,需要的朋友可以参考下
    2023-03-03

最新评论