1 使用线程池方法:
data:image/s3,"s3://crabby-images/1f6f9/1f6f96741e768aa293da9bda0b1abb95d8e4b007" alt=""
运行效果可以看到:
data:image/s3,"s3://crabby-images/43197/4319714766f82cafc5260ea82f8f499bc7790beb" alt=""
2 使用countDownLatch同步工具类
CountDownLatch countDownLatch=new CountDownLatch(2);
Log.e("tanlin", "主线程开始执行");
ThreadPoolExecutor threadPoolExecutor=new ThreadPoolExecutor(10,10,0l,
TimeUnit.MILLISECONDS,new LinkedBlockingQueue<>());
threadPoolExecutor.submit(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(1000);
Log.e("tanlin", "子线程执行1");
countDownLatch.countDown();
}catch (InterruptedException e) {
e.printStackTrace();
}
}
});
threadPoolExecutor.submit(new Runnable() {
@Override
public void run() {
try {
Thread.sleep(1000);
Log.e("tanlin", "子线程执行2");
countDownLatch.countDown();
}catch (InterruptedException e) {
e.printStackTrace();
}
}
});
try {
countDownLatch.await();
}catch (InterruptedException e) {
e.printStackTrace();
}
Log.e("tanlin", "两个子线程执行完,主线程继续执行");
data:image/s3,"s3://crabby-images/0a553/0a5534817ea14183b79a98dccb11989da38d2a86" alt=""
这两种方式比较优雅,当然还有其他各种方式。
网友评论