Java 线程sleep(),join()方法
sleep()方法是让线程“睡眠”(即停下来等待)所指定的一段时间,但是不会释放线程获得的锁。在睡眠结束后,线程立即恢复执行,参与竞争运行资源。参数long millis指定毫秒数,int nanos指定纳秒数。
线程mThread1打印数字每打印一个数字休眠1s,mThread2打印字母每次休眠500ms
package teach;
class mThread1 extends Thread{
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=0;i<20;i++) {
try {
sleep(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(this.getName()+":"+i);
}
}
}
class mThread2 extends Thread{
@Override
public void run() {
// TODO Auto-generated method stub
for(int i=0;i<20;i++) {
try {
sleep(500);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(this.getName()+":"+(char)(i+65));
}
}
}
public class thread {
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
mThread1 thread1=new mThread1();
mThread2 thread2=new mThread2();
thread1.start();
//Thread.sleep(3000);
System.out.println(thread1.isAlive());
thread2.start();
}
}
结果
按理论来说,字母比数字先执行完,差不多打印两个字母后打印一个数字。
去掉run方法中的sleep,在主方法中调用Thread.sleep(3000);结果如下:
也就是打印数字结束后才打印字母
现在在run方法中使用sleep,主线程也使用Thread.sleep(3000);结果:
打印数字的线程还“活着”。也就是说主方法调用sleep()是让主方法休眠,sleep()是静态方法,不是属于对象的。只是在主方法休眠的3秒里打印数字结束了,主线程才恢复。
如果想真正的让打印数字结束之后才打印字母,使用join()方法;
去掉上面run方法的sleep(),主方法:
public static void main(String[] args) throws InterruptedException {
// TODO Auto-generated method stub
mThread1 thread1=new mThread1();
mThread2 thread2=new mThread2();
thread1.start();
thread1.join();
System.out.println(thread1.isAlive());
thread2.start();
}
结果:
打印数字线程完毕,并且已经“死掉了”(isAlive()方法判断线程是否“存活”),开始打印字母。
另外yield()方法也是线程的静态方法,作用是让线程停下来变为就绪状态。变为就绪状态后,有可能又获得了执行的机会,又开始执行(相当于没有起效果)。