iteye_10484
iteye_10484
2011-03-30 18:24
浏览 298
已采纳

如何判断多个线程是否结束

我有个程序设计不明白了,
main里有有3部分代码,
第一部分开出15个线程,
第二部分需要第一部分的结果进行分析,
但是我无法判断第一步开出的15个线程是否结束,我只能手工屏蔽第二和第三部分代码,然后依次执行。
高手有什么办法没,如何判断15个线程是否结束。

就是如何让主线程等待所有子线程执行完毕

public class Test {

/**
 * @param args
 */
public static void main(String[] args) {
    // TODO Auto-generated method stub
    // 第一部分从正式数据库抽取数据,插入临时表
    for (int i = 0; i < 15; i++) {
        new Thread() {
            public void run() {
                // TODO Auto-generated method stub
                System.out.println("在正式数据库抽取数据:"
                        + Thread.currentThread().getName());
                try {
                    Thread.sleep(10);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        }.start();
    }
    // 第二部分,对临时表数据进行整理
    System.out.println("插入临时表进行分析");
    // 结果展示
    System.out.println("从临时表中读取信息,结果展示");
}

}


问题补充
我看一下,我原来考虑过线程组,但是也没有什么好的方法

你说的java.lang.Thread.State == TERMINATED 就可以

可以实现吗,这句应该写在哪里,第一部分代码的后面吗?

高手再指点下呀
问题补充
1: Thread.join()
2: CountDownLatch
3: CyclicBarrier

这三个都可以解决我说的那个问题吗,我是想第一部分15个线程都执行完后,再执行第二部分程序
问题补充
join(),是目标线程.join,是让目标线程加入,当前线程等目标线程执行完,再执行,这个可顶不符合我的要求。
问题补充
CountDownLatch 正解,看API描述,就是这个东西,太感谢了,这个问题困扰我很久。
问题补充
感谢各位高手的帮忙,我有思路了,谢谢了
  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

6条回答 默认 最新

  • NanguoCoffee
    NanguoCoffee 2011-03-30 18:24
    已采纳

    Part 1:
    Thread[] ts = new Thread[15];
    for(int i=0;i<ts.length();i++){
    ts[i] = new Thread(){...}
    ts[i].start();
    }
    for(int i=0;i<ts.length();i++){
    ts[i].join();
    }
    ...
    Part2 : ....

    [quote="albb0608"]join(),是目标线程.join,是让目标线程加入,当前线程等目标线程执行完,再执行,这个可顶不符合我的要求。[/quote]

    点赞 评论
  • iteye_14409
    iteye_14409 2011-03-30 18:24

    通过Thread#getState() 来判断!

    java.lang.Thread.State == TERMINATED 就可以!

    也可以通过Profile工具查看的!

    点赞 评论
  • NanguoCoffee
    NanguoCoffee 2011-03-30 18:24

    1: Thread.join()
    2: CountDownLatch
    3: CyclicBarrier

    点赞 评论
  • itwangxinli_nyist
    itwangxinli_nyist 2011-03-30 18:24

    将创建好的线程加入数组或者List,然后遍历List,启动线程
    然后遍历线程数组,调用join()等待线程执行结束,接下来的事情就可以继续做了。

    点赞 评论
  • qinker
    qinker 2011-03-30 19:50

    请看我的文章:并发编程一波流之CyclicBarrier.
    [url]http://www.iteye.com/topic/980944[/url]
    有实际代码,肯定能解决你的问题。 :D

    点赞 评论
  • iteye_14409
    iteye_14409 2011-03-30 20:18

    楼主使用ExecutorCompletionService,具体怎么弄,我不告诉你!呵呵!

    线程池都能做的!

    点赞 评论

相关推荐