程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> 淺析c/c++中函數的參數傳遞

淺析c/c++中函數的參數傳遞

編輯:關於C++

淺析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;
}

輸入成果:

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved