在C++里面,指針是一種比較麻煩的操作,但是我們又不得不用.因為他給我們編程以很大的靈活性
下面我講以下指針作為函數(shù)參數(shù)時的問題
在函數(shù)參數(shù)中,編譯器總是要為函數(shù)的每個參數(shù)制作臨時副本,指針
參數(shù)p 的副本是 _p,編譯器使 _p = p 。如果函數(shù)體內(nèi)的程序修改了_p 的內(nèi)容,就導致
參數(shù)p 的內(nèi)容作相應的修改。這就是指針可以用作輸出參數(shù)的原因。在本例中,_p 申請
了新的內(nèi)存,只是把_p 所指的內(nèi)存地址改變了,但是p 絲毫未變。
以上是林銳博士在高質(zhì)量C++編程中的描述
下面我們結(jié)合描述給出調(diào)試CODE
?Example Code:
void GetMemory(char *p,int num)
{
?p = (char*)malloc(sizeof(char)*num);
//?return
}
void main()
{
?char *str = NULL;
?GetMemory(str,100);
?strcpy(str,"Hello World");//出錯
}
首先我們先看看asm
004010B8?? mov???????? dword ptr [ebp-4],0
004010BF?? push??????? 64h
004010C1?? mov???????? eax,dword ptr [ebp-4]
004010C4?? push??????? eax
004010C5?? call??????? @ILT+50(GetMemory) (00401037)
str 地址:12FF7C
其副本地址:12FF28
在存入?yún)?shù)的時候,同時都指向00 00 00 00
在執(zhí)行p = (char*)malloc(sizeof(char)*num);之后
12FF28指向的內(nèi)容變成了20 1C 43 00了.
林銳博士在這邊的意思是只用指向指針的指針,這種方法我們在第二種方法種介紹,
下面給出我的一種看法,大家覺得好不好
我的方法:
char *GetMemory(char *p,int num)
{
?p = (char*)malloc(sizeof(char)*num);
?return p;
}
void main()
{
?char *str = NULL;
?str = GetMemory(str,100);
?strcpy(str,"Hello World");
?cout<<str<<endl;
}
可以簡化為:
char *GetMemory(int num)
{
?char *p = (char*)malloc(sizeof(char)*num);
?return p;
}
void main()
{
?char *str = NULL;
?str = GetMemory(100);
?strcpy(str,"Hello World");
?cout<<str<<endl;
}
林銳博士的看法:
void GetMemory(char **p,int num)
{
???*p = (char*)malloc(sizeof(char)*num);
}
void main()
{
???char *str = NULL;
???GetMemory(&str,100);
???strcpy(str,"Hello,World");
???cout <<str<<endl;
}