Java线程中start和run方法全面解析
自定义线程两种方法
自定义一个runnable接口的实现类,然后构造一个thread,即对thread传入一个runnable接口类。
new一个thread或者写个thread子类,覆盖它的run方法。(new一个thread并覆盖run方法实际上是匿名内部类的一种方式)
示例代码
publicstaticvoidmain(String[]args){ newThread(newRunnable(){ @Override publicvoidrun(){ System.out.println("createthreadbypassingarunnabletarget!"); } }).start(); newThread(){ @Override publicvoidrun(){ System.out.println("createthreadbyOverriderunmethod!"); }; }.start(); }
上述对应1和2两种构造线程的方法,由于代码写法设计匿名类对象,现做如下辅助说明:
1.对于第一段我直接传入了匿名runnable实例,可以自定义一个runnable实例,然后newthread(runnable)这种形式获得thread;
2.对于第二段可以专门定义一个class去extendsthread基类,然后new这个新的线程类。
3.对于这两段都是直接newthread创建匿名类对象,可以定义一个变量thread1、thread2,然后利用thread1.start()thread2.start()启动线程;
源码剖析
这两种方式有什么区别呢,二者最终效果是一样的,源代码级别来看,thread的默认的run方法(不被覆写的话)是调用target(target不为空的话)的run方法,target就是我们传入的runnable接口类。
publicsynchronizedvoidstart(){ if(threadStatus!=0) thrownewIllegalThreadStateException(); group.add(this); booleanstarted=false; try{ start0(); started=true; }finally{ try{ if(!started){ group.threadStartFailed(this); } }catch(Throwableignore){ } } }
线程的start最终会调用native的start0,此方法会使得jvm虚拟机调用线程的run方法。
publicvoidrun(){ if(target!=null){ target.run(); } }
这里的target是一个Thread中的runnable的对象
privateRunnabletarget;
总结
复写thread的run方法,则就是start的时候线程去执行的run方法。
传入runnable,则start的时候线程执行默认run方法,run方法中会对传入的target进行调用,调用target的run方法。
两者效果一样,这里只是帮助我们去看代码细节差异。
以上所述是小编给大家介绍的Java线程中start和run方法全面解析,希望对大家有所帮助,如果大家想了解更多内容敬请关注毛票票!