gpt4 book ai didi

java - 在循环中使用线程,如何在到达主程序末尾之前完成for循环?

转载 作者:行者123 更新时间:2023-12-01 15:07:35 24 4
gpt4 key购买 nike

我的预期输出是

Count : 1
Count : 2
Count : 3
Count : 4
Count : 5

我尝试过同步和锁定,但它们都不起作用。我到达

Ending Main

比我完全完成循环还要早。当前输出为:

Starting Main
Count : 1
Count : 2
Count : 3
Count : 4
Ending Main
Count : 5

知道为什么 Count : 5 是在 Ending Main 之后吗?这是我的代码:

public class Demo {
public static void main( String [] args ) {
System.out.println( "Starting Main" ) ;
for ( int i = 1 ; i <= 5 ; i++ ) {
Thread numberThread = new Thread(new NumberTask(i)) ;
numberThread.start() ;
}
System.out.println( "Ending Main" ) ;
}
}

class NumberTask implements Runnable {
private Lock bankLock = new ReentrantLock();
int count ;
public NumberTask( int count ) {
this.count = count ;
}

synchronized public void run() {
bankLock.lock();
try {
System.out.println( "Count : " + count ) ;
} finally {
bankLock.unlock();
}
}
}

最佳答案

Any Idea why "Count : 5" is after "Ending Main"?

当线程启动时,不能保证它立即开始运行。当新线程初始化时,派生新线程的线程继续运行是正常的。因此,主线程启动第 5 个线程后,它会继续运行并击败该线程到 System.out.println("Ending Main"); 语句。

重要的是要认识到线程的全部意义在于它们以异步方式运行。由于线程可以调度在并发运行的单独 CPU/内核上,因此通常很难预测线程程序中的操作顺序。例如。您也可能会看到“Count 2”打印在“Count 1”之前,只是因为 thread race conditions 。我刚刚启动 500 个线程运行它,我看到:

Count : 128
Count : 130
Count : 129
Count : 131

此外,由于您的 bankLock 是您的 NumberTask 类的本地对象,因此它不会在线程之间锁定。您可以将锁静态设置为 NumberTask,以便每个类有一个锁,或者您可以在 main 中实例化锁并将其传递到 NumberTask构造函数。这里确实不需要锁,因为 System.out 是一个 PrintStram,它是一个synchronized 对象。 synchronized run() 方法也是如此。由于您将在 NumberTask 实例上进行同步,因此它不会执行任何操作,因为没有其他线程会在同一对象上进行同步。

关于java - 在循环中使用线程,如何在到达主程序末尾之前完成for循环?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12769408/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com