JAVA和Nginx 教程大全

网站首页 > 精选教程 正文

「Java知识」java控制线程的执行顺序,计数器|信号量你用过吗?

wys521 2024-11-06 20:34:36 精选教程 21 ℃ 0 评论

不废话,直接上代码

## 保证线程的顺序

第一种:使用join

 for (int i = 0; i < 10; i++){
     Thread t1 = new Thread(new Runnable() {
         public void run() {
             System.out.println("我是t1线程");
         }
     });
 
     Thread t2 = new Thread(new Runnable() {
         public void run() {
             System.out.println("我是t2线程\n");
         }
     });
     t1.start();
     t1.join();
     t2.start();
     
     Thread.sleep(500);
 }

第二种:使用单线程池

 ExecutorService executor = Executors.newSingleThreadExecutor();
 for (int i = 0; i < 10; i++){
     Thread t1 = new Thread(new Runnable() {
         public void run() {
             System.out.println("我是t1线程");
         }
     });
 
     Thread t2 = new Thread(new Runnable() {
         public void run() {
             System.out.println("我是t2线程\n");
         }
     });
     executor.submit(t1);
     executor.submit(t2);
     
     Thread.sleep(500);
 }
 executor.shutdown();

第三种:使用CountDownLatch计数器

 for (int i = 0; i < 10; i++){
     final CountDownLatch count = new CountDownLatch(1);
     Thread t1 = new Thread(new Runnable() {
         public void run() {
             System.out.println("我是t1线程");
             count.countDown();
         }
     });
 
     Thread t2 = new Thread(new Runnable() {
         public void run() {
             try {
                 count.await();
             } catch (InterruptedException e) {
                 e.printStackTrace();
             }
             System.out.println("我是t2线程\n");
         }
     });
 
     t2.start();
     t1.start();
 
     Thread.sleep(500); 
 }

第四种:使用wait和notify控制

第五种:使用CyclicBarrier循环屏障

第六种:使用Semaphore信号量

第七种:使用消息队列等中间件,如zookeeper、kafka等

你问我为什么后面几种高大上的为什么没有例子,因为它们例子写起来代码有点多,如果没有使用过的同学一定要百度了解下,特别是CyclicBarrierSemaphore,这两个是java后面新增的并发包中的类,好用不贵。不然都不好意思说自己精通java

总结

以上多种控制线程顺序的方法,可以根据不同的场景使用不同的方法。每种方法都有他们的使用场景,在不同的场景选择最合适的方法才能事半功倍。

上面例子中没有考虑并发的情况


本头条号主要是Java常用关键技术点,通用工具类的分享;以及springboot+springcloud+Mybatisplus+druid+mysql+redis+swagger+maven+docker等集成框架的技术分享;datax、kafka、flink等大数据处理框架的技术分享。文章会不断更新,欢迎码友关注点赞收藏!

关注多的话,后面会录制一些视频教程,图文和视频结合,比如:图书介绍网站系统、抢购系统、大数据中台系统等。技术才是程序猿的最爱,码友们冲啊

Tags:

本文暂时没有评论,来添加一个吧(●'◡'●)

欢迎 发表评论:

最近发表
标签列表