我在Eclipse和Netbeans中获得了相同java多线程程序的不同输出?

时间:2014-06-20 04:31:22

标签: java multithreading netbeans

我在eclipse和Netbeans ide中得到了这个多线程代码的不同输出,我不知道它是如何产生的,以及这背后的逻辑是什么。

每当我执行此代码时,它将显示不同的输出,Plz帮助我。

公共类MyThread2扩展了线程
{

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

2 个答案:

答案 0 :(得分:3)

线程由JVM设置。 JVM选择运行具有最高优先级的Runnable线程。每当创建新的Java线程时,它都具有与创建它的线程相同的优先级。所以,在你的情况下,两个线程都具有相同的优先级!因此,JVM使用自己的算法(Round Robin Scheduling)来获取线程并按该顺序选择和执行它们。它没有固定的顺序,对执行进行评级是完全不可预测的!

它会为同一IDE上的不同样本运行提供不同的输出,即NetbeansEclipse。你可以尝试同时运行!它可能在以前运行时出现故障,因为这些是由JVM安排的。

答案 1 :(得分:2)

线程由JVM调度,没有特定的顺序。这就是你看到涉及线程的相同代码的不同输出的原因。

JVM使用内部操作系统底层线程管理来管理线程,而在几乎所有可用的操作系统中,线程调度的算法都是循环的。