java线程的执行顺序_Javaの线程之多线程执行顺序

发现一个规律,如果多个线程运行一个模块(runnable),在run()方法里耗时越短就越能按照线程的start顺序,如果是0耗时,那么线程A(loop)—>B(loop)—>C(loop),如果耗时较长,那么可能A的loop执行第三次循环的时候,B开始进入首次循环,然后过不久C也可以loop,可能A还没有循环完毕。

也就是说如果A能立即执行完毕,那么后面的线程将在A执行完后执行,如果A耗时很长,俺么就会在A没有执行完毕的时候,执行Other线程,但是这还是基于Thread的调用start所在的位置。

代码:

public class Look implementsRunnable{public static voidmain(String[] args) {

Look look= newLook();

Thread thA= new Thread(look,"Thread A");

Thread thB= new Thread(look,"Thread B");

Thread thC= new Thread(look,"Thread C");

thA.start();

thB.start();

thC.start();

}

@Overridepublic voidrun() {//TODO Auto-generated method stub

for(int i=0;i<=5;++i){try{

Thread.sleep(10);

}catch(InterruptedException e) {//TODO Auto-generated catch block

e.printStackTrace();

}

System.out.println(Thread.currentThread().getName()+" synchronized loop "+i);

}

}

}

几次实验:

测试一:0耗时,按顺序执行...

b92f09206b7f93d16b2fd10bf361df05.png

测试二:耗时3毫秒,就会是这种情况,前一个线程执行到第四次loop的时候,下个线程开始loop。

dd5f8e0d83f54559ef6f0a6b6ce259cb.png

测试三:耗时5毫秒,A线程进行第二次loop的时候,B就开始loop,然后等A执行完毕后,C开始loop,B继续..

bbdd275db6099ae0d85445ebeae6b2ef.png

测试四:A loop0此时还是A一个线程,Aloop2的时候B开始Loop0,此事A和B各进一个loop然后C开始Loop0...

d3b66207164bffbc987a55c12e2408e3.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值