淺析c/c++中函數的參數傳遞。本站提示廣大學習愛好者:(淺析c/c++中函數的參數傳遞)文章只能為提供參考,不一定能成為您想要的結果。以下是淺析c/c++中函數的參數傳遞正文
上面來看一段代碼,看看三種傳遞方法發生的成果。
#include <cstdlib>
#include <iostream>
using namespace std;
void change1(int n)
{
cout << "值傳遞--函數操作地址" << &n << endl;
n ++;
}
void change2(int &n)
{
cout << "援用傳遞--函數操作地址:" << &n << endl;
n ++;
}
void change3(int *n)
{
cout << "指針傳遞--函數操作地址" << n << endl;
*n = *n + 1;
}
int main(int argc)
{
int n = 10;
cout << "實參地址:" << &n << endl;
cout << "原值 n =" << n << endl;
change1(n);
cout << "afterchange1 n =" << n << endl;
change2(n);
cout << "afterchange2 n =" << n << endl;
change3(&n);
cout << "afterchange3 n =" << n << endl;
system("PAUSE");
return EXIT_SUCCESS;
}
打印成果以下:
可見,原值為10的實參n,change1函數沒有轉變它的值,而change2、change3函數則勝利轉變了它的值。
同時,檢查函數的操作地址,也會發明,change1的操作地址其實不是實參n的地址。
解釋:
1.值傳遞的情勢不會傳遞n自己,故不克不及轉變n的值。
2.援用傳遞、指針傳遞,現實上就是將地址傳入,可以或許勝利對該地址停止操作。
然則須要留意:
1.援用和指針傳遞前,須要被初始化。
2.援用和指針在內存中開拓的貯存單位應當是正當單位,不該該是NULL。
3.一旦援用被初始化,就不克不及轉變援用的關系,而指針可以隨便轉變指向的對象。
關於沒有初始化指針或許援用的情形,我們再來看一個例子:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <iostream>
using namespace std;
void init(char *p)
{
p = (char *)malloc(100);
cout << "指針傳遞--函數操作地址" << p << endl;
}
int main()
{
char *p = NULL;
cout << "實參原地址" << p << endl;
init(p);
if(p)
{
strcpy(p, "hello");
printf("%s \n", p);
}
else
{
printf("%s", "p not init \n");
}
free(p);
system("PAUSE");
return EXIT_SUCCESS;
}
輸入成果: