關(guān)于函數(shù)外初始化與函數(shù)內(nèi)初始化之前一直分的不是太清,也不太在意。昨天終于出現(xiàn)了這方面的問(wèn)題,所以決定好好看下,以下是這次的一些收獲,先看測(cè)試代碼:
#include "stdafx.h"
#include <iostream>
using namespace std;
bool FillStr(char *&szDst, int nSize)
{
bool bRet = false;
if (nSize > 0)
{
szDst = (char*)malloc(sizeof(char) * nSize);
memset(szDst, 0, sizeof(char) * nSize);
strcpy(szDst, "hello, world");
bRet = true;
}
return bRet;
}
bool FillStr(char *szDst)
{
bool bRet = false;
if (szDst)
{
strcpy(szDst, "hello, 5.1");
bRet = true;
}
return bRet;
}
int _tmain(int argc, _TCHAR* argv[])
{
char* szWord = NULL;
// 第一種
//FillStr(szWord, 64);
// 第二種
szWord = (char*)malloc(sizeof(char) * 64);
memset(szWord, 0, sizeof(char) * 64);
FillStr(szWord);
printf("%s/n", szWord);
if (szWord)
{
free(szWord);
szWord = NULL;
}
getchar();
return 0;
}
1.函數(shù)內(nèi)初始化:bool FillStr(char *&szDst, int nSize);第一個(gè)參數(shù)中的&一定不能少,這是因?yàn)樵诤瘮?shù)外部我們只聲明了這個(gè)指針,具體這個(gè)指針指向內(nèi)存中的哪個(gè)地址我們并不知道,所以&是為了說(shuō)明傳遞的是這個(gè)指針的引用,那么在函數(shù)內(nèi)初始化后這個(gè)指針的地址也就是外面指針的地址了。
第二個(gè)參數(shù)是我們要分配的字符個(gè)數(shù)。
2.函數(shù)外初始化:bool FillStr(char *szDst);
這個(gè)函數(shù)的參數(shù)加不加&都可以,因?yàn)閭鬟M(jìn)來(lái)的時(shí)候已經(jīng)初始化了,已經(jīng)有了一個(gè)確切的地址,如果不加&的話傳進(jìn)來(lái)的就是原來(lái)地址的拷貝,如果加&的話就是同一個(gè)指針。所以不管怎樣它們傳進(jìn)來(lái)的都是一樣的地址,對(duì)其操作都是對(duì)同一塊內(nèi)存的操作。
雖然上面兩種方法都可以達(dá)到相同的效果,但是我認(rèn)為還是第二種方式好些,這樣符合誰(shuí)分配誰(shuí)釋放的原則。