多线程执行操作相同资源时,有时会出现子线程耗时操作,导致子线程未结束就执行主线程造成共同操作的资源数据结果出错,需用到线程同步,以下给出几种线程同步方法
1.join
t1.start();
t1.join();
//执行其他
2.判断线程是否存活
t1.start();
while(t1.Alive()){
}
//执行其他
3.判断存活的线程是否大于1
t1.start();
while(Thread.activeCount()>1){
Thread.yield();
}
4.通过同步工具类CountDownLatch实现
这种办法需要CountDownLatch对象侵入线程run()方法的代码中。最终执行结果和前面几种解决办法一致。
CountDownLatch通过await()方法阻塞主线程,等待其他线程运行结束,通过countDown()方法来释放锁,主线程开始执行。
总结:
在这四种解决办法中,一、二两种办法需要知道线程的名字,当有很多线程同时执行的时候,有时候,我们是无法直观的知道每个线程的名字,这两个办法用的很少见。第四种办法在多线程的情况下也可以使用,就是需要设置CountDownLatch latch = new CountDownLatch(n),指定需要等待的线程数。第三种办法无需知道线程的名字和线程的数量,使用起来很直观。
原创文章,作者:745907710,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/274789.html