java中 等待所有子线程结束 后再执行一段代码。
2017-06-02 15:54
609 查看
今天有一个需求是:在一个方法中开启了一个子线程来执行操作,返回值依赖于子线程的执行结果,这样如果要返回正确的值,就需要开启子线程后
主线程等待子线程,然后子线程执行结束后,主线程再继续执行。
主线程等待子线程需要用到:CountDownLatch
代码如下:
import java.util.concurrent.CountDownLatch;
public class Counter {
public static int count = 0;
static CountDownLatch cdl=new CountDownLatch(1000);//这里的数字,开启几个线程就写几
public synchronized static void inc() throws InterruptedException{//注意,如果不加上synchronized,由于并发写入,结果会小于1000
Thread.sleep(1);
count++;
cdl.countDown();
}
public static void main(String[] args) throws InterruptedException{
for(int i = 0; i < 1000; i++){
new Thread(new Runnable(){
public void run() {
// TODO Auto-generated method stub
try {
Counter.inc();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
).start();
}
cdl.await();//主线程等待子线程执行输出
System.out.println(count);
}
}
主线程等待子线程,然后子线程执行结束后,主线程再继续执行。
主线程等待子线程需要用到:CountDownLatch
代码如下:
import java.util.concurrent.CountDownLatch;
public class Counter {
public static int count = 0;
static CountDownLatch cdl=new CountDownLatch(1000);//这里的数字,开启几个线程就写几
public synchronized static void inc() throws InterruptedException{//注意,如果不加上synchronized,由于并发写入,结果会小于1000
Thread.sleep(1);
count++;
cdl.countDown();
}
public static void main(String[] args) throws InterruptedException{
for(int i = 0; i < 1000; i++){
new Thread(new Runnable(){
public void run() {
// TODO Auto-generated method stub
try {
Counter.inc();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
).start();
}
cdl.await();//主线程等待子线程执行输出
System.out.println(count);
}
}
相关文章推荐
- Java实现等待所有子线程结束后再执行一段代码的方法
- java中 等待所有子线程结束 后再执行一段代码。
- Java中等待所有线程都执行结束
- Java多线程--让主线程等待所有子线程执行完毕代码
- java中等待所有线程都执行结束
- java中等待所有线程都执行结束(转)
- Java主线程等待所有子线程执行完毕再执行解决办法集
- Java多线程--让主线程等待所有子线程执行完毕
- Java多线程等待所有线程结束(CountDownLatch/CyclicBarrier)
- java多线程实现主线程等待所有子线程执行完毕
- Java多线程--让主线程等待所有子线程执行完毕【转】
- Java主线程等待所有子线程执行完毕再执行解决办法
- 主线程中使用join等待所有子线程执行结束
- [置顶] [转]Java多线程--让主线程等待所有子线程执行完毕
- Java多线程--让主线程等待所有子线程执行完毕
- Java多线程--让主线程等待所有子线程执行完毕
- java 多线程同步--多个线程启动执行同一段代码
- Java:多线程等待所有线程结束(CountDownLatch/CyclicBarrier) .
- Java多线程--让主线程等待所有子线程执行完毕
- Java主线程等待所有子线程执行完毕再执行解决办法集