既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
🍴示例:
创建Semaphore实例,初始化为4,表示4个可用资源
acquire方法表示申请资源(P操作),release方法表示释放资源(V操作)
创建20个线程,每个线程都尝试申请资源,sleep等待1秒后,释放资源,观察程序执行结果
👁🗨️代码展示:
import java.util.concurrent.Semaphore;
public class SemaphoreTest {
public static void main(String[] args) {
Semaphore sem = new Semaphore(4);
Runnable runnable = new Runnable() {
@Override
public void run() {
try {
System.out.println("申请资源");
sem.acquire();
System.out.println("获取到资源");
Thread.sleep(1000);
sem.release();
System.out.println("释放资源");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
};
for(int i = 0;i < 20;i++){
Thread t = new Thread(runnable);
t.start();
}
}
}
👁🗨️打印结果说明:
🥭线程计数器(CountDownLatch)
CountDownLatch也属于共享锁,其内部有一个int类型的属性表示可以同时并发并行的线程的数量
同时等待N个任务执行结束
举例说明:
比如跑步比赛,必须等所有运动员通过终点才能公布成绩
🍭CountDownLatch的构造方法:
🍡CountDownLatch的常用方法:
**🥩使用场景:**等待多个线程全部执行完,再执行某个任务
**🥩注意:**CountDownLatch只能减不能加
🍴示例:
构造CountDownLatch实例,初始化为10,表示有10个任务需要完成
每个任务执行完成后,调用countDown(),CountDownLatch内部计数器自减
主线程调用await(),等待所有线程执行完毕,也就是计数器值为0,再继续执行主线程后续任务
👁🗨️代码展示:
import java.util.concurrent.CountDownLatch;
public class CountDownLatchTest {
public static void main(String[] args) throws InterruptedException {
CountDownLatch latch = new CountDownLatch(10);
Runnable runnable = new Runnable() {
@Override
public void run() {
System.out.println(Thread.currentThread().getName());
latch.countDown();
}
![img](https://img-blog.csdnimg.cn/img_convert/d0842084c5605c6dcd2b3015ee27bdbc.png)
![img](https://img-blog.csdnimg.cn/img_convert/29886f1206fed760078befe2209fe3fc.png)
**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上C C++开发知识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**
识点,真正体系化!**
**由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新**
**[如果你需要这些资料,可以戳这里获取](https://bbs.csdn.net/topics/618668825)**