在書寫代碼與閱讀代碼的時候,經常會看到這一句代碼: typedef void *HANDLE ,它是何方神聖呢?如何理解呢?
不理解它的時候,感覺它很神奇,知道它以後,它就是個typedef的定義,只不過是void*類型罷了,也就是HANDLE等價於void *,我們可以叫它披著句柄皮的指針(PS:指針和句柄是有區別的,在這說句廢話);
對於void* 神通廣大,因為它作為函數參數or函數返回值,能夠接受任何類型的指針;也就是來者不拒,是指針就接受(so open ,Aha)。但應用的時候,應該注意,void * 必須指向具體的類型;例如:
void * HappyPt;
int* pi=static_cast<int*>HappyPt;; //注意喽,在這裡具體到了int*哦!
具體用法如下所示:
1.還記得它嗎?
void * __cdecl memset(_Out_opt_bytecapcount_(_Size) void * _Dst, _In_ int _Val, _In_ size_t _Size);
這是memset這個函數的原型,在這裡你可以毫不留情的把void* 換成HANDLE,memset就是為了將傳遞進來的地址開始的n個字節的值全部賦值成某個特定的值,所以沒必要知道是什麼類型的指針,就用void類型指針代替了。用作參數的時候,我們一般不關心傳遞進來的地址類型;
用作返回值的時候,一般是返回一個地址,至於這個地址你要做什麼用那是你決定的,最常見的就是malloc了,它返回void類型指針作為分配好的內存區的首地址,至於是什麼類型,就需要用戶自己來指定了。
示例
typedef void *HANDLE;
HANDLE m_exitThreadEvent;
m_exitThreadEvent = CreateEvent(NULL,FALSE,FALSE,NULL);
HANDLE CreateEvent(
LPSECURITY_ATTRIBUTES lpEventAttributes,
BOOL bManualReset,
BOOL bInitialState,
LPTSTR lpName
);
《C++ 設計新思維》 下載見 http://www.linuxidc.com/Linux/2014-07/104850.htm
C++ Primer Plus 第6版 中文版 清晰有書簽PDF+源代碼 http://www.linuxidc.com/Linux/2014-05/101227.htm
讀C++ Primer 之構造函數陷阱 http://www.linuxidc.com/Linux/2011-08/40176.htm
讀C++ Primer 之智能指針 http://www.linuxidc.com/Linux/2011-08/40177.htm
讀C++ Primer 之句柄類 http://www.linuxidc.com/Linux/2011-08/40175.htm
將C語言梳理一下,分布在以下10個章節中: