【多线程】java多线程 测试例子 详解wait() sleep() notify() start() join()方法 等

java实现多线程,有两种方法:

1》实现多线程,继承Thread,资源不能共享

2》实现多线程  实现Runnable接口,可以实现资源共享

*wait()方法 在哪个线程中调用 则当前线程处于等待状态【在main方法中调用A.wait(),则是main线程等待,而不是A线程等待】
* join()方法 作用类似与wait()方法 理解:如上处调用join()方法
* 【注意:在A线程中调用B.join()--------表示A一直等待,直到B运行完成后才继续运行A】
* 在A线程中调用B.join(1000)----表示A仅等待B线程1000ms时间,不管B线程中是否有sleep()或者wait()等情况,只要超时,则A继续运行,B你随意
* notify()方法 无论B.wait()在A线程中运行还是在B线程中运行【在哪个线程中运行,则哪个线程等待】,但是想让那个等待的线程被唤醒,必须用B.notify()唤醒,不管在何处唤醒【即不管在A线程中调用B.notify()或者在main线程中调B.notify()】。

 1 package com.sxd.thread;
 2
 3 /**
 4  * 测试  多线程 的wait()
 5  * @author Administrator
 6  *
 7  */
 8 public class TestThread implements Runnable{
 9
10     static Thread thread1 = null;
11     static Thread thread2 = null;
12     static int count = 20;    //用来标识一下 各个线程运行的顺序
13
14     public TestThread() {
15
16     }
17
18     public static void main(String[] args) throws InterruptedException {
19         System.out.println("main线程运行---->");
20         TestThread testThread = new TestThread();
21         thread1 = new Thread(testThread,"AA");
22         thread2 = new Thread(testThread,"BB");
23         thread1.start();
24         thread2.start();
25         System.out.println("休眠--->main线程休眠5s");
26         Thread.sleep(5000);//main线程 睡5s
27         System.out.println("唤醒--->AA线程");
28         synchronized (thread1) {
29             thread1.notify();//唤醒AA线程  因为AA线程让thread1调用的wait,所以需要thread1唤醒
30         }
31
32         //BB线程先走  main线程等待2000ms
33         synchronized (thread2) {
34             thread2.join(2000);//理解:此处在主线程中: thread2调用join()方法,则main线程暂停运行,直到thread2【调用它的线程对象】运行结束才继续运行main线程
35         }
36         System.out.println("等不及BB线程,main线程输出");
37     }
38
39     /**
40      * wait()方法  在哪个线程中调用  则当前线程处于等待状态【在main方法中调用A.wait(),则是main线程等待,而不是A线程等待】
41      * join()方法  作用类似与wait()方法  理解:如上处调用join()方法
42      *                 注意:在A线程中调用B.join()--------表示A一直等待,直到B运行完成后才继续运行A
43      *                       在A线程中调用B.join(1000)----表示A仅等待B线程1000ms时间,不管B线程中是否有sleep()或者wait()等情况,只要超时,则A继续运行,B你随意
44      * notify()方法  无论B.wait()在A线程中运行还是在B线程中运行【在哪个线程中运行,则哪个线程等待】,但是想让那个等待的线程被唤醒,必须用B.notify()唤醒,不管在何处唤醒【即不管在A线程中调用B.notify()或者在main线程中调用B.notify()】。
45      */
46     @Override
47     public void run() {
48         for (int i = 0; i < 10; i++) {
49             synchronized (TestThread.class) {
50                 System.out.println(Thread.currentThread().getName()+"线程运行"+count--);
51             }
52
53             if(i == 2){
54                 if(Thread.currentThread().getName().equals("AA")){//若是AA线程  则让AA进行wait()
55                     synchronized (thread1) {//wait()   join()   notify() 这类方法 都需要synchronized
56                         try {
57                             System.out.println("等待--->AA开始等待");
58                             thread1.wait();
59                         } catch (InterruptedException e) {
60                             e.printStackTrace();
61                         }
62                     }
63                 }
64             }
65             if(i == 3){
66                 if(Thread.currentThread().getName().equals("BB")){//若是BB线程  则让BB睡眠5000ms
67                     try {
68                         System.out.println("休眠--->BB线程进入休眠");
69                         Thread.sleep(5000);
70                     } catch (InterruptedException e) {
71                         e.printStackTrace();
72                     }
73                 }
74             }
75         }
76     }
77 }

View Code

 

代码流程:

 

 

运行结果:

 

时间: 2024-10-26 07:07:27

【多线程】java多线程 测试例子 详解wait() sleep() notify() start() join()方法 等的相关文章

Java RandomAccessFile的用法详解_java

RandomAccessFile RandomAccessFile是用来访问那些保存数据记录的文件的,你就可以用seek( )方法来访问记录,并进行读写了.这些记录的大小不必相同:但是其大小和位置必须是可知的.但是该类仅限于操作文件. RandomAccessFile不属于InputStream和OutputStream类系的.实际上,除了实现DataInput和 DataOutput接口之外(DataInputStream和DataOutputStream也实现了这两个接口),它和这两个类系毫

Java Serializable和Parcelable详解及实例代码_java

对 Serializable和Parcelable理解 1.首先他们两个接口都是为了实现对象的序列化,使之可以传递,所谓序列化就是将对象信息装换成可以存储的介质的过程. 2.Serializable是jdk所提供的序列化接口,该接口存在于io包下,可想用于输入输出,使用非常简单,只要让你的类实现此接口就ok了:可以使用transient关键字修饰你不想序列化的属性. 3.Parcelable是sdk所提供的序列化接口,使用较上者麻烦,实现此接口后,需要重写writeToParcel方法,将需要序

Tomcat与Java Web开发技术详解连载之一

web|详解 本章介绍如何在Tomcat上创建和发布Web应用.这里首先讲解Tomcat的目录结构以及Web应用的目录结构,接着介绍如何将HTML.Servlet.JSP和Tag Library部署到Web应用中,然后介绍把整个Web应用打包并发布的方法,最后介绍如何在Tomcat上配置虚拟主机. 本章侧重于讨论Web应用的结构和发布方法,所以没有对本章的Servlet和JSP的例子进行详细解释,关于Servlet和JSP的技术可以分别参考其它章节的内容. 2.1 Tomcat的目录结构 在To

Tomcat与Java Web开发技术详解连载之三

web|详解 2.2.8 创建并发布WAR文件 Tomcat既可以运行采用开放式目录结构的Web应用,也可以运行WAR文件.在本书配套光盘的sourcecode/chapter2/helloapp目录下提供了所有源文件,只要把整个helloapp目录拷贝到/webapps目录下,即可运行开放式目录结构的helloapp应用.在Web应用的开发阶段,为了便于调试,通常采用开放式的目录结构来发布Web应用,这样可以方便地更新或替换文件.如果开发完毕,进入产品发布阶段,应该将整个Web应用打包为WAR

怎样使用Java Servlet动态生成图片详解

servlet|动态|详解 在Web应用中,经常需要动态生成图片,比如实时股市行情,各种统计图等等,这种情况下,图片只能在服务器内存中动态生成并发送给用户,然后在浏览器中显示出来. 本质上,浏览器向服务器请求静态图片如JPEG时,服务器返回的仍然是标准的http响应,只不过http头的contentType不是text/html,而是image/jpeg而已,因此,我们在Servlet中只要设置好contentType,然后发送图像的数据流,浏览器就能正确解析并显示出图片. 在Java中,jav

SQL SERVER分区具体例子详解

原文:SQL SERVER分区具体例子详解 在日常工作中,我们会遇到以下的情况,一个表每日数万级的增长,而查询的数据通常是在本月或今年,以前的数据偶尔会用到,但查询和插入的效率越来越慢,用数据库分区会有助于解决这个问题.关于分区的理论知识网上很多我这里就不在累赘,我从一个实际例子出发,看如何将一个已经运行了很长时间的普通表进行分区. 提出问题 需解决问题:有一个数据表数据很大,我们通常的查询是在一个季度中.我们需要将以往年份的数据按不同年份存在文件组里,当年的数据分为4个季度存,如果到了新的一年

Java中final关键字详解_php技巧

谈到final关键字,想必很多人都不陌生,在使用匿名内部类的时候可能会经常用到final关键字.另外,Java中的String类就是一个final类,那么今天我们就来了解final这个关键字的用法. 主要介绍:一.final关键字的基本用法.二.深入理解final关键字 一.final关键字的基本用法 在Java中,final关键字可以用来修饰类.方法和变量(包括成员变量和局部变量).下面就从这三个方面来了解一下final关键字的基本用法. 1.修饰类 当用final修饰一个类时,表明这个类不能

Java 中的注解详解及示例代码_java

在Java中,注解(Annotation)引入始于Java5,用来描述Java代码的元信息,通常情况下注解不会直接影响代码的执行,尽管有些注解可以用来做到影响代码执行. 注解可以做什么 Java中的注解通常扮演以下角色 编译器指令 构建时指令 运行时指令 其中 Java内置了三种编译器指令,本文后面部分会重点介绍 Java注解可以应用在构建时,即当你构建你的项目时.构建过程包括生成源码,编译源码,生成xml文件,打包编译的源码和文件到JAR包等.软件的构建通常使用诸如Apache Ant和Mav

Tomcat与Java Web开发技术详解连载之二

web|详解 2.2.4 部署HTML文件 在helloapp目录下加入index.htm文件,这个文件仅仅用来显示一串带链接的字符"Welcome to HelloApp", 它链接到login.jsp文件.以下是index.htm文件的代码: <html><head><title>helloapp</title></head><body ><p><font size="7"