CountDownLatch用于主线程等待工作线程完成工作,注意,这里与pthread_join不一样:
pthread_join是只要线程active就会阻塞,线程结束就会返回.一般用于主线程回收工作线程.
CountDownLatch可以保证工作线程的任务执行完毕,主线程再对工作线程进行回收
1. 原理
CountDownLatch,本质上来说,是一个thread safe的计数器,用于主线程和工作线程的同步.
我所知道的用法有两种:
第一种:在初始化时,需要指定主线程需要等待的任务的个数(count),当工作线程完成 Task Callback后对计数器减1,而主线程通过wait()调用阻塞等待技术器减到0为止.
第二种:初始化计数器值为1,在程序结尾将创建一个线程执行countDown操作并wait()当程序执行到最后会阻塞直到计数器减为0,这可以保证线程池中的线程都start了线程池对象才完成析够,这是一个坑,我在实现ThreadPool的过程中遇到过
2. 实现
CountDownLatch是一个Thread Safe的Couter,它支持的方法主要是两个countDown()和wait()
countDown就是对counter原子的执行减1操作
wait就使用条件变量等待counter减到0然后notify.

本文介绍了C++中封装POSIX线程库实现的CountDownLatch,用于主线程等待工作线程完成任务。CountDownLatch是一个线程安全的计数器,支持两种使用场景:等待特定数量的工作线程完成任务或确保所有线程启动后再继续执行。文中详细讲解了原理,并提供了CountDownLatch头文件和源文件的实现。
最低0.47元/天 解锁文章
8830

被折叠的 条评论
为什么被折叠?



