多线程学习(五)线程的调度-休眠&优先级

转自:http://lavasoft.blog.51cto.com/62575/221790

Java线程:线程的调度-休眠

Java线程调度是Java多线程的核心,只有良好的调度,才能充分发挥系统的性能,提高程序的执行效率。
这里要明确的一点,不管程序员怎么编写调度,只能最大限度的影响线程执行的次序,而不能做到精准控制。
线程休眠的目的是使线程让出CPU的最简单的做法之一,线程休眠时候,会将CPU资源交给其他线程,以便能轮换执行,当休眠一定时间后,线程会苏醒,进入 准备状态 等待执行。
 
线程休眠的方法是Thread.sleep(long millis) 和Thread.sleep(long millis, int nanos) ,均为静态方法,那调用sleep休眠的哪个线程呢?简单说,哪个线程调用sleep,就休眠哪个线程。
 
/** 
* Java线程:线程的调度-休眠 

* @author leizhimin 2009-11-4 9:02:40 
*/
 
public  class Test { 
         public  static  void main(String[] args) { 
                Thread t1 =  new MyThread1(); 
                Thread t2 =  new Thread( new MyRunnable()); 
                t1.start(); 
                t2.start(); 
        } 


class MyThread1  extends Thread { 
         public  void run() { 
                 for ( int i = 0; i < 3; i++) { 
                        System.out.println( "线程1第" + i +  "次执行!"); 
                         try { 
                                Thread.sleep(50); 
                        }  catch (InterruptedException e) { 
                                e.printStackTrace(); 
                        } 
                } 
        } 


class MyRunnable  implements Runnable { 
         public  void run() { 
                 for ( int i = 0; i < 3; i++) { 
                        System.out.println( "线程2第" + i +  "次执行!"); 
                         try { 
                                Thread.sleep(50); 
                        }  catch (InterruptedException e) { 
                                e.printStackTrace(); 
                        } 
                } 
        } 
}
 
线程2第0次执行! 
线程1第0次执行! 
线程1第1次执行! 
线程2第1次执行! 
线程1第2次执行! 
线程2第2次执行! 

Process finished with exit code 0
 
从上面的结果输出可以看出,无法精准保证线程执行次序。

Java线程:线程的调度-优先级 

与线程休眠类似,线程的优先级仍然无法保障线程的执行次序。只不过,优先级高的线程获取CPU资源的概率较大,优先级低的并非没机会执行。 
线程的优先级用1-10之间的整数表示,数值越大优先级越高,默认的优先级为5。 
在一个线程中开启另外一个新线程,则新开线程称为该线程的子线程,子线程初始优先级与父线程相同。
 
/** 
* Java线程:线程的调度-优先级 

* @author leizhimin 2009-11-4 9:02:40 
*/
 
public  class Test { 
         public  static  void main(String[] args) { 
                Thread t1 =  new MyThread1(); 
                Thread t2 =  new Thread( new MyRunnable()); 
                t1.setPriority(10); 
                t2.setPriority(1); 

                t2.start(); 
                t1.start(); 
        } 


class MyThread1  extends Thread { 
         public  void run() { 
                 for ( int i = 0; i < 10; i++) { 
                        System.out.println( "线程1第" + i +  "次执行!"); 
                         try { 
                                Thread.sleep(100); 
                        }  catch (InterruptedException e) { 
                                e.printStackTrace(); 
                        } 
                } 
        } 


class MyRunnable  implements Runnable { 
         public  void run() { 
                 for ( int i = 0; i < 10; i++) { 
                        System.out.println( "线程2第" + i +  "次执行!"); 
                         try { 
                                Thread.sleep(100); 
                        }  catch (InterruptedException e) { 
                                e.printStackTrace(); 
                        } 
                } 
        } 
}
 
线程1第0次执行! 
线程2第0次执行! 
线程2第1次执行! 
线程1第1次执行! 
线程2第2次执行! 
线程1第2次执行! 
线程1第3次执行! 
线程2第3次执行! 
线程2第4次执行! 
线程1第4次执行! 
线程1第5次执行! 
线程2第5次执行! 
线程1第6次执行! 
线程2第6次执行! 
线程1第7次执行! 
线程2第7次执行! 
线程1第8次执行! 
线程2第8次执行! 
线程1第9次执行! 
线程2第9次执行! 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值