函數外初始化與函數內初始化具體解析。本站提示廣大學習愛好者:(函數外初始化與函數內初始化具體解析)文章只能為提供參考,不一定能成為您想要的結果。以下是函數外初始化與函數內初始化具體解析正文
關於函數外初始化與函數內初始化之前一向分的不是太清,也不太在乎。昨天終究湧現了這方面的成績,所以決議好悅目下,以下是此次的一些收成,先看測試代碼:
#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.函數內初始化:bool FillStr(char *&szDst, int nSize);
第一個參數中的&必定不克不及少,這是由於在函數內部我們只聲清楚明了這個指針,詳細這個指針指向內存中的哪一個地址我們其實不曉得,所以&是為了解釋傳遞的是這個指針的援用,那末在函數內初始化後這個指針的地址也就是裡面指針的地址了。
第二個參數是我們要分派的字符個數。
2.函數外初始化:bool FillStr(char *szDst);
這個函數的參數加不加&都可以,由於傳出去的時刻曾經初始化了,曾經有了一個確實的地址,假如不加&的話傳出去的就是本來地址的拷貝,假如加&的話就是統一個指針。所以不論如何它們傳出去的都是一樣的地址,對其操作都是對統一塊內存的操作。
固然下面兩種辦法都可以到達雷同的後果,然則我以為照樣第二種方法好些,如許相符誰分派誰釋放的准繩。