本文实例讲述了Java线程的新建和就绪状态。分享给大家供大家参考,具体如下:
一 点睛
当线程被创建启动以后,它既不是一启动就进入执行状态,也不是一直处于执行状态,在线程的生命周期中,它要经过新建、就绪、运行、阻塞和死亡5种状态。当线程启动后,它不可能一直霸占CPU独自运行,所以CPU需要在多个线程之间切换,于是线程状态也会多次在运行和就绪之间切换。
当程序使用new关键字创建一个线程后,该线程就处于新建状态。
当线程对象调用start()方法之后,该线程就处于就绪状态,处于这个状态的线程并没有开始运行,只是表示该线程可以运行了。至于该线程何时开始运行,取决于JVM里线程调度器的调度。
自动线程使用start()方法,而不是run()方法,永远不要调用线程对象的run()方法。否则系统把线程对象当作一个普通对象,而run()方法也是一个普通方法,而不是线程执行体。
二 代码
public class InvokeRun extends Thread { private int i ; // 重写run方法,run方法的方法体就是线程执行体 public void run() { for ( ; i < 100 ; i++ ) { // 直接调用run方法时,Thread的this.getName返回的是该对象名字, // 而不是当前线程的名字。 // 使用Thread.currentThread().getName()总是获取当前线程名字 System.out.println(Thread.currentThread().getName() + " " + i); // ① } } public static void main(String[] args) { for (int i = 0; i < 100; i++) { // 调用Thread的currentThread方法获取当前线程 System.out.println(Thread.currentThread().getName() + " " + i); if (i == 20) { // 直接调用线程对象的run方法, // 系统会把线程对象当成普通对象,run方法当成普通方法, // 所以下面两行代码并不会启动两条线程,而是依次执行两个run方法 new InvokeRun().run(); new InvokeRun().run(); } } } }
三 运行
......
main 93
main 94
main 95
main 96
main 97
main 98
main 99
main 0
main 1
main 2
main 3
main 4
main 5
......
四 说明
上面程序创建对象后直接调用了线程对象的run()方法,程序的运行结果是整个程序只有一个线程:主线程。
如果直接调用线程对象的run()方法,则run()方法里不能直接通过getName()方法来获得当前执行线程的名字,而是需要使用Thread.currentThread()方法先获得当前线程,再调用线程对象的getName()方法来获得线程的名字。
启动线程的正确方法是调用Thread对象的start()方法,而不是直接调用run()方法,否则就会变成单线程程序。
调用了run()方法之后,该线程已经不再处于新建状态,不要再次调用线程对象的start()方法。
只能对处于新建状态的线程调用start()方法,否则会引发异常。
如果希望调用子线程的start()方法后子线程立即开始执行,程序可以使用Thread.sleep(1)来让当前运行的线程(主线程)睡眠1毫秒,因为1毫秒内CPU不会空闲,它会去执行另一个处于就绪状态的线程,这样就可以让子线程立即开始执行。
更多java相关内容感兴趣的读者可查看本站专题:《Java进程与线程操作技巧总结》、《Java数据结构与算法教程》、《Java操作DOM节点技巧总结》、《Java文件与目录操作技巧汇总》和《Java缓存操作技巧汇总》
希望本文所述对大家java程序设计有所帮助。