聲明:本文為原創(chuàng)博文,轉載請注明出處。

     在libuv中,有一個只使用簡單的宏封裝成的高效隊列(queue),現在我們就來看一下它是怎么實現的。

     首先,看一下queue中最基本的幾個宏:

photoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網站設計培訓,網站建設培訓

1 typedef void *QUEUE[2];2 3 /* Private macros. */4 #define QUEUE_NEXT(q)       (*(QUEUE **) &((*(q))[0]))5 #define QUEUE_PREV(q)       (*(QUEUE **) &((*(q))[1]))6 #define QUEUE_PREV_NEXT(q)  (QUEUE_NEXT(QUEUE_PREV(q)))7 #define QUEUE_NEXT_PREV(q)  (QUEUE_PREV(QUEUE_NEXT(q)))

photoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網站設計培訓,網站建設培訓

     首先,QUEUE被聲明成一個"具有兩個char*元素的指針數組",如下圖:

延伸閱讀

學習是年輕人改變自己的最好方式-Java培訓,做最負責任的教育,學習改變命運,軟件學習,再就業(yè),大學生如何就業(yè),幫大學生找到好工作,lphotoshop培訓,電腦培訓,電腦維修培訓,移動軟件開發(fā)培訓,網站設計培訓,網站建設培訓學習是年輕人改變自己的最好方式