标签:常用 String Thread System 线程 辅助工具 println 三种 out
三种常用的辅助工具类
CountDownLatch
-
是一个执行减法操作的辅助计数器
//计数器
public class CountDownLatchTest {
public static void main(String[] args) throws InterruptedException {
//总数是六,必须在执行任务时再使用
CountDownLatch countDownLatch = new CountDownLatch(6);
for (int i = 0; i <=6 ; i++) {
new Thread(()->{
System.out.println(Thread.currentThread().getName()+" 开门");
countDownLatch.countDown(); //执行-1操作
},String.valueOf(i)).start();
}
countDownLatch.await();//等待计数器归零,再执行向下操作
System.out.println("关门");
}
}
CyclicBarrier
//加法计数器
public class CyclicBarrierTest {
public static void main(String[] args) {
CyclicBarrier cyclicBarrier = new CyclicBarrier(6,()->{
System.out.println("线程执行完毕");
});
for (int i = 0; i <=6 ; i++) {
final int temp=i;
new Thread(()->{ //lambda表达式不能直接获取for循环中的变量,需要通过final类型转换
System.out.println(Thread.currentThread().getName()+"线程执行了"+temp);
try {
cyclicBarrier.await();
} catch (InterruptedException e) {
e.printStackTrace();
} catch (BrokenBarrierException e) {
e.printStackTrace();
}
},String.valueOf(i)).start();
}
}
}
Semaphore
//运行许可
public class SemaphoreTest {
public static void main(String[] args) {
//线程数量:抽象的看成停车位
Semaphore semaphore = new Semaphore(3); //相当于存在三个停车位
for (int i = 0; i <=6 ; i++) {
new Thread(()->{
try {
semaphore.acquire();//获得,假设线程已满,会等待其他线程被释放为止
System.out.println(Thread.currentThread().getName()+"抢到了车位");
TimeUnit.SECONDS.sleep(2);//线程休眠两秒
System.out.println(Thread.currentThread().getName()+"离开了车位");
} catch (InterruptedException e) {
e.printStackTrace();
}finally{
semaphore.release(); //释放线程,会将当前的释放量+1,然后唤醒等待
}
},String.valueOf(i)).start();
}
}
}
作用:
-
多个共享资源互斥使用
-
并发限流,控制最大线程数
标签:常用,String,Thread,System,线程,辅助工具,println,三种,out 来源: https://www.cnblogs.com/wfy-studying/p/16155058.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。