java.lang.InterruptedException: sleep interrupted异常

使用单元测试,创建线程池,然后启动一个线程,在线程中sleep(5*1000),这是回报

java.lang.InterruptedException: sleep interrupted异常,原因是因为单元测试启动的主线程很快就结束了,而子线程确sleep5秒,使得主线程强行打断子线程的sleep,因此抛出异常,解决办法是可以在单元测试的最后加上sleep(10*1000),目的是不让主线程在子线程前结束。

 

 

 @Test

    public void getUserPwd(){

        Test1Thread thread1 = new Test1Thread(userService,

                "ptstest3", MD5Encrypt.md5("12345678"));

        taskExecutor.execute(thread1);

 

try {

            Thread.sleep(10*1000);

        } catch (InterruptedException e) {

            // TODO Auto-generated catch block

            e.printStackTrace();

        }

    }

 

 

 

 

public class Test1Thread implements Runnable {

 

    public UserService userService;

    public String loginId;

    public String pwd;

 

    public Test1Thread(UserService userService,String loginId,String pwd){

        this.pwd=pwd;

        this.loginId=loginId;

        this.userService=userService;

    }

 

    /* (non-Javadoc)

     * @see java.lang.Runnable#run()

     */

    @Override

    public void run() {

        // TODO Auto-generated method stub

        try {

            userService.updateUserPassword(loginId, pwd);

            Thread.sleep(5*1000);

        } catch (InterruptedException e) {

            e.printStackTrace();

            System.out.println("error--------");

        }

 

    }

 

}

 

 

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值