在《手寫(xiě)
線程池 - C語(yǔ)言版》中,已經(jīng)實(shí)現(xiàn)了 C 語(yǔ)言版的線程池,如果我們也學(xué)過(guò) C 的話,可以將其改為 C 版本,這樣代碼不管是從使用還是從感觀上都會(huì)更簡(jiǎn)潔一些。對(duì)這些代碼做從 C 到 C 的遷移主要用到了 C 三大特性中的封裝,因此難度不大,對(duì)應(yīng) C 初學(xué)者來(lái)說(shuō)有助于提高編碼水平和對(duì)面向?qū)ο蟮睦斫?,?duì)于熟練掌握了 C 的人來(lái)說(shuō)就是
張飛吃豆芽 -- 小菜一碟(so easy)
。關(guān)于線程的在此就不再過(guò)多闡述,對(duì)于前面文章中設(shè)計(jì)的線程池,按照面向?qū)ο蟮乃枷脒M(jìn)行拆分可以分為兩部分(純屬個(gè)人見(jiàn)解,有不同的想法也正常):任務(wù)隊(duì)列類 和
線程池類。
1. 任務(wù)隊(duì)列
1.1 類聲明
//?定義任務(wù)結(jié)構(gòu)體
using?callback?=?void(*)(void*);
struct?Task
{
????Task()
????{
????????function?=?nullptr;
????????arg?=?nullptr;
????}
????Task(callback?f,?void*?arg)
????{
????????function?=?f;
????????this->arg?=?arg;
????}
????callback?function;
????void*?arg;
};
//?任務(wù)隊(duì)列
class?TaskQueue
{
public:
????TaskQueue();
????~TaskQueue();
????//?添加任務(wù)
????void?addTask(Task