android 单元测试 多线程,多线程之单元测试(Junit)

多线程测试服务

1.新建一个核心数为100 的线程池

ExecutorService service = Executors.newFixedThreadPool(100);

2.执行一个阻塞不大的任务

service.execute(()->{

try {

for (int i =0; i <100; i++) {

Thread.sleep(100);

System.out.println("我阻塞了100ms");

}

}catch (InterruptedException e) {

e.printStackTrace();

}

});

测试发现什么都没有打印

查阅资料发现

junit 单元测试当主线程执行完毕,主线程会关闭,并且关闭子线程

解决方法

使用在主线程中使用join 等待子线程执行完

try {

Thread.currentThread().join();

} catch (InterruptedException e) {

e.printStackTrace();

}

结果

61184ed7eb37

Join方法.png

使用CountDownLatch 等待

2.1 任务类RunableTask

public class RunableTask implements Runnable {

private CountDownLatch countDownLatch;

public RunableTask(CountDownLatch countDownLatch) {

this.countDownLatch = countDownLatch;

}

@Override

public void run() {

try {

Thread.sleep(100);

System.out.println("我阻塞了100ms");

} catch (InterruptedException e) {

e.printStackTrace();

}finally {

countDownLatch.countDown();

}

}

}

2.2 测试方法

@Test

public void runCountDown() {

for (int i = 0; i < 100; i++) {

service.execute(new RunableTask(countDownLatch));

}

try {

countDownLatch.await();

log.info("执行成功");

} catch (InterruptedException e) {

e.printStackTrace();

log.log(Level.WARNING,e,()->"抛出中断异常");

}

}

结果

61184ed7eb37

CoutDownLautch 起效果.png

当然还可以让主线程睡眠来等待子线程

github地址

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值