C++中void和void*指针的含义 (指针类型的含义)
生活随笔
收集整理的這篇文章主要介紹了
C++中void和void*指针的含义 (指针类型的含义)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
轉載自:http://blog.csdn.net/lee_shuai
指針有兩個屬性:指向變量/對象的地址和長度,但是指針只存儲地址,長度則取決于指針的類型;編譯器根據指針的類型從指針指向的地址向后尋址,指針類型不同則尋址范圍也不同,比如:
int*從指定地址向后尋找4字節作為變量的存儲單元 double*從指定地址向后尋找8字節作為變量的存儲單元void即“無類型”,void *則為“無類型指針”,可以指向任何數據類型。
1 ?void的作用
1)? ?對函數返回的限定
a) 當函數不需要返回值時,必須使用void限定。例如: voidfunc(int, int);2)? ?對函數參數的限定
a) 當函數不允許接受參數時,必須使用void限定。例如: intfunc(void)。2 ?void* 指針意義
2.1???void類型指針可以指向任意類型的數據,即可用任意數據類型的指針對void指針賦值。
int *pint;
void *pvoid; //它沒有類型,或者說這個類型不能判斷出指向對象的長度
pvoid = pint; //只獲得變量/對象地址而不獲得大小,但是不能 pint =pvoid; 2.2???如果要將pvoid賦給其他類型指針,則需要強制類型轉換如:
pint = (int *)pvoid; //轉換類型也就是獲得指向變量/對象大小2.3???void指針不能解引用(即取內容的意思)
*pvoid //錯誤 要想解引用一個指針,或者使用“->”運算符復引用一部分,都要有對于指針指向的內存的解釋規則。反過來
例如,int *p;
那么,當你后面解引用p的時候,編譯器就會把從p指向的首地址開始的四個字節看作一個整數的補碼。
因為void指針只知道指向變量/對象的起始地址,而不知道指向變量/對象的大小(占幾個字節)所以無法正確引用
?
2.4???如果函數的參數可以是任意類型指針,那么應聲明其參數為void*。
典型的如內存操作函數memcpy和memset的函數原型分別為:
void*memcpy(void* dest,const void* src, size_t len); void*memset(void*buffer,intc,size_tnum);這樣,任何類型的指針都可以傳入memcpy和memset中,這也真實地體現了內存操作函數的意義,因為它操作的對象僅僅是一片內存,而不論這片內存是什么類型。如果 memcpy和memset的參數類型不是void*,而是char*,那是不具有普遍適用性的
轉載于:https://www.cnblogs.com/clemente/p/10905335.html
總結
以上是生活随笔為你收集整理的C++中void和void*指针的含义 (指针类型的含义)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Unity整合TortoiseSVN
- 下一篇: 一分钟读懂互联网广告竞价策略GFP+GS