时间:2021-05-20
一、多线程的sleep方法
1.Thread.sleep(毫秒)
2.sleep方法是一个静态方法
3.该方法的作用:阻塞当前线程,腾出CPU,让给其他线程
4.sleep的异常注意事项,以及中断休眠的一种方式及其注意点
package com.bjpowernode.java_learning;public class D106_1_ { public static void main(String[] args) throws InterruptedException{ Processer106 p1 = new Processer106(); p1.start(); //需求:子线程启动后0.5s之后打断它的休眠 Thread.sleep(500); p1.interrupt(); //这样就会是子线程打断休眠 //这个底层的实现方法是一个调用中断异常的方式,因此,这个休眠之后的操作就不会执行了 //在这个代码中就会直接进行下一次循环 for (int i=0;i<5;i++) { System.out.println(Thread.currentThread().getName()+"---->"+i); //下面这个语句也可以使用对象.sleep();因为sleep方法是一个静态方法。 //即p1.sleep(200);这个main线程也会休眠200ms Thread.sleep(200); } }}class Processer106 extends Thread{ //Thread中的run方法不抛出异常,因此重写run方法,在run方法的声明位置不能使用throws //所以run方法中只能使用try...catch..... public void run() { for (int i=0;i<5;i++) { System.out.println(Thread.currentThread().getName()+"--->"+i); try { Thread.sleep(1000); //当前线程阻塞1s System.out.println(i); } catch(InterruptedException e) { e.printStackTrace(); } } } //m1方法是可以使用throws的}二、如何正确的停止一个线程(不使用interrupt方法)
使用一个flag就可以达到我们的目的
packagepackage com.bjpowernode.java_learning;public class D106_2_InterruptSleep { public static void main(String[] args) throws Exception{ Processer106_2 p = new Processer106_2(); Thread t = new Thread(p); t.setName("t"); t.start(); //5s之后终止 Thread.sleep(5000); p.run1 = false; //这种非异常的方法更好,因为不会抛出异常。 }}class Processer106_2 implements Runnable{ Boolean run1 = true; public void run() { for (int i=0;i<10;i++) { if(run1) { try { Thread.sleep(1000); } catch(InterruptedException e) { e.printStackTrace(); } System.out.println(Thread.currentThread().getName()+"-->"+i); } else { return; } } }}三、Thread.yield
1.该方法是一个静态方法
2.作用:给同一个优先级的线程让位,但是让位时间不固定
3.和sleep方法相同,就是yield时间不固定
package com.bjpowernode.java_learning;public class D106_3_ThreadYield { public static void main(String[] args) throws InterruptedException { Processer106_3 p = new Processer106_3(); Thread t = new Thread(p); t.setName("t"); t.start(); //在主线程中 for (int i=0;i<1000;i++) { System.out.println(Thread.currentThread().getName()+"-->"+i); } }}class Processer106_3 implements Runnable{ public void run() { for (int i=0;i<1000;i++) { System.out.println(Thread.currentThread().getName()+"-->"+i); if(i%20 == 0) { Thread.yield(); } } }}四、源码:
D106_1_SleepMehthodAnalysis.java
D106_2_InterruptSleep.java
D106_3_ThreadYield.java
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了Java线程让步yield用法。分享给大家供大家参考,具体如下:一点睛yield()方法是一个和sleep()方法有点类似的方法,它是Thread
Java两种延时thread和timer详解及实例代码在Java中有时候需要使程序暂停一点时间,称为延时。普通延时用Thread.sleep(int)方法,这很
和线程停止相关的三个方法/*中断线程。如果线程被wait(),join(),sleep()等方法阻塞,调用interrupt()会清除线程中断状态,并收到Int
本文实例讲述了Java检测线程中断状态的方法。分享给大家供大家参考,具体如下:一代码publicclassInterruptCheck{publicstatic
Java如何实现线程中断?通过调用Thread类的实例方法interrupt。如下:Threadthread=newThread(){@Overridepubl