Java线程的新建和就绪状态实例分析
本文实例讲述了Java线程的新建和就绪状态。分享给大家供大家参考,具体如下:
一点睛
当线程被创建启动以后,它既不是一启动就进入执行状态,也不是一直处于执行状态,在线程的生命周期中,它要经过新建、就绪、运行、阻塞和死亡5种状态。当线程启动后,它不可能一直霸占CPU独自运行,所以CPU需要在多个线程之间切换,于是线程状态也会多次在运行和就绪之间切换。
当程序使用new关键字创建一个线程后,该线程就处于新建状态。
当线程对象调用start()方法之后,该线程就处于就绪状态,处于这个状态的线程并没有开始运行,只是表示该线程可以运行了。至于该线程何时开始运行,取决于JVM里线程调度器的调度。
自动线程使用start()方法,而不是run()方法,永远不要调用线程对象的run()方法。否则系统把线程对象当作一个普通对象,而run()方法也是一个普通方法,而不是线程执行体。
二代码
publicclassInvokeRunextendsThread { privateinti; //重写run方法,run方法的方法体就是线程执行体 publicvoidrun() { for(;i<100;i++) { //直接调用run方法时,Thread的this.getName返回的是该对象名字, //而不是当前线程的名字。 //使用Thread.currentThread().getName()总是获取当前线程名字 System.out.println(Thread.currentThread().getName() +""+i);//① } } publicstaticvoidmain(String[]args) { for(inti=0;i<100;i++) { //调用Thread的currentThread方法获取当前线程 System.out.println(Thread.currentThread().getName() +""+i); if(i==20) { //直接调用线程对象的run方法, //系统会把线程对象当成普通对象,run方法当成普通方法, //所以下面两行代码并不会启动两条线程,而是依次执行两个run方法 newInvokeRun().run(); newInvokeRun().run(); } } } }
三运行
......
main93
main94
main95
main96
main97
main98
main99
main0
main1
main2
main3
main4
main5
......
四说明
上面程序创建对象后直接调用了线程对象的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程序设计有所帮助。