一開始沒(méi)有理解,導(dǎo)致對(duì)這個(gè)概念非常的模糊和不解姥敛。最近看完《 徹底搞定C語(yǔ)言指針詳解》奸焙,里面關(guān)于指針的指針的解釋有了頓悟感。
其實(shí),很好理解与帆,是我把它想復(fù)雜了了赌。
我們都知道,實(shí)參和形參的區(qū)別玄糟。形參并無(wú)法改變實(shí)參搭伤,這就是值傳遞。還有一種叫指針傳遞苹享,實(shí)質(zhì)就是去操作指針的指向?qū)ο蠖簟@尤缦拢?/p>
Exchg2(int *px, int *py)
{
int tmp=*px;
*px=*py;
*py=tmp;
print(“*px=%d,*py=%d\n”,*px,*py);
}
main()
{
int a=4;
int b=6;
Exchg2( &a,&b);
Print (“a=%d,b=%d\n”, a, b);
}
這時(shí)候打印出來(lái)的結(jié)果是什么呢?
a=6,b=4 px = 6, py =4
為什么郭卫?
Exchg2這個(gè)函數(shù)的參數(shù)是兩個(gè)int型指針砍聊,是地址,所以你要用&取a和b的地址傳入贰军。在Exchg2的函數(shù)內(nèi)部玻蝌,兩個(gè)指針?biāo)赶虻闹到粨Q了,因?yàn)橹澳阋呀?jīng)把a(bǔ)和b的地址傳遞給了px和py這兩個(gè)指針词疼,所以現(xiàn)在操作px和py指向的值俯树,也會(huì)導(dǎo)致a和b所指向的值發(fā)生變化。
這個(gè)雖然饒了些贰盗,但還是勉強(qiáng)能理解许饿。那么,如果是指針的指針呢舵盈?
如下:
這個(gè)函數(shù)本意是為傳入的字符串開辟空間米辐,但是仔細(xì)看,它真的達(dá)到了這個(gè)效果嗎书释?
void GetMemory(char *p, int num)
{
p = (char *)malloc(sizeof(char) * num);
}
main(int argc, _TCHAR* argv[])
{
char *str = NULL;
GetMeory(str, 100);
strcpy(str,"Hello");
cout << str << endl;
return 0;
}
顯然不能翘贮,為什么?這其實(shí)和值傳遞是一個(gè)意思爆惧,你傳遞進(jìn)來(lái)的是一個(gè)指針實(shí)參str狸页,而函數(shù)的形參p去替換了實(shí)參,所以后面操作的都是形參而已扯再,并不會(huì)對(duì)實(shí)參有影響芍耘。這就不符合我們要求了啊,那怎么辦熄阻?上一個(gè)例子斋竞,我們傳入實(shí)參的地址,然后交換地址指向的值秃殉,來(lái)達(dá)到我們交換實(shí)參的目的坝初,那么在這邊我們也可以這么干啊浸剩。
void GetMeory(char **p, int num)
{
*p = (char *)malloc(sizeof(char) * num);
//*p = new char[num]; //C++當(dāng)中
}
int _tmain(int argc, _TCHAR* argv[])
{
char *str = NULL;
GetMeory(&str, 100);
strcpy(str,"Hello");
cout << str << endl;
return 0;
}
這不就是把str的地址&str傳入了GetMeory函數(shù)內(nèi)嘛,只不過(guò)這個(gè)str本身也是一個(gè)指針鳄袍,管它呢绢要,還有就是GetMeory中的參數(shù)變成了char **p,這也很好理解拗小,我傳入的是指針的指針重罪,如果你還是只用指針char *p來(lái)接收的話,不就也只是操作形參了和值傳遞沒(méi)區(qū)別了啊哀九。我要操作的是實(shí)參指針剿配,所以形參必須是實(shí)參的指針,也就是char **阅束, 好繞口惨篱,不過(guò) 不難理解,你想想為什么值傳遞沒(méi)有改變實(shí)參就知道了围俘。
最后我們改變的是p,也就是形參char p的值琢融,因?yàn)?/em>是取值符界牡。指的是p指向的值,也就是一個(gè)地址漾抬,是指針宿亡。和指針傳遞的那個(gè)例子不同,那個(gè)例子是為了交換兩者指向的值纳令,所以要看你想實(shí)現(xiàn)什么挽荠,來(lái)決定操作什么值。