我在eclipse和Netbeans ide中得到了这个多线程代码的不同输出,我不知道它是怎么来的,这背后的逻辑是什么.
每当我执行此代码时,它将显示不同的输出,Plz帮助我.
公共类MyThread2扩展了Thread
{
public void run()
{
`System.out.println("r1");` ``
try ``
{
Thread.sleep(500);
}
catch(Exception e)
{
}
System.out.println("r2");
}
public static void main(String args[])
{
MyThread2 t1=new MyThread2();
MyThread2 t2=new MyThread2();
t1.start();
t2.start();
System.out.println(t1.isAlive());
System.out.println(t2.isAlive());
}
}
Eclipse中的输出:
R1
R1
真正
真正
R2
R2
和Netbeans的输出:
R1
真正
真正
R1
R2
R2
解决方法:
线程由JVM调配. JVM选择运行具有最高优先级的Runnable线程.每当创建新的Java线程时,它都具有与创建它的线程相同的优先级.所以,在你的情况下,两个线程都具有相同的优先级!因此,JVM使用自己的算法(Round Robin Scheduling)来获取线程并按该顺序选择和执行它们.它没有固定的顺序,对执行进行评级是完全不可预测的!
它会为同一IDE上的不同样本运行提供不同的输出,即Netbeans或Eclipse.你可以尝试同时运行!它可能在以前的运行中出现故障,因为这些是由JVM调度的.