多线程程序中,为什么线程执行顺序不总是和代码顺序一致?
线程执行顺序
问题:
在如下代码中,为什么线程执行顺序与预想不符?
public class testmythread { public static void main(string[] args) { myrunnable myrunnable = new myrunnable(); thread thread = new thread(myrunnable, "myrunnable"); thread.start(); system.out.println(thread.getname()); } } public class myrunnable implements runnable { @override public void run() { for (int i = 0; i < 10; i++) { system.out.println("myrunnable" + new date().gettime() + "---" + i + "--count"); } } }
答案:
实际上,线程执行顺序与代码顺序无关。多线程程序是并发的,这意味着不同的线程可以同时执行,并且执行顺序可能会因系统而异。在给定的示例中,可能出现以下执行顺序:
- main 方法中的打印语句执行,输出线程名称。
- myrunnable 类的 run 方法执行,输出计数消息。
但是,由于线程调度器的不可预测性,实际执行顺序可能会有所不同,即 myrunnable 线程可能先执行,然后再输出线程名称。
原因:
这是因为 java 使用时间片调度器,它在不同的线程之间共享处理器时间。当一个线程执行时,可能会被中断并允许另一个线程执行。
调整打印输出以显式显示线程执行顺序:
为了更明确地显示线程执行顺序,可以在 myrunnable 类中添加一个 println 语句,如下所示:
public class MyRunnable implements Runnable { @Override public void run() { System.out.println("Thread " + Thread.currentThread().getName() + " started"); for (int i = 0; i < 10; i++) { System.out.println("MyRunnable" + new Date().getTime() + "---" + i + "--count"); } System.out.println("Thread " + Thread.currentThread().getName() + " finished"); } }
这样,你就可以观察到哪个线程在特定时间输出消息,从而进一步了解线程执行顺序。
以上就是多线程程序中,为什么线程执行顺序不总是和代码顺序一致?的详细内容,更多请关注其它相关文章!