C/C++中參數傳遞有兩種方式,傳值或傳地址(傳引用),通常我們要在被調用函數中改變一個變量的值就需要傳地址調用方式,例如:
void swap_by_value(int a, int b)
{
int temp;
temp = a;
a = b;
b = temp;
}
void swap_by_ptr(int* pa, int* pb)
{
int temp;
temp = *pa;
*pa = *pb;
*pb = temp;
}
int main(int argc, char* argv[])
{
int a=5, b=6;
swap_by_value(a, b);
printf("a=%d, b=%d\n", a, b);
swap_by_ptr(&a, &b);
printf("a=%d, b=%d\n", a, b);
return 0;
}
很顯然,通過傳值調用并不能改變main函數中的a與b,要想改變a與b的值就必須通過傳地址方式,然后在被調用函數中通過指針訪問到主函數中的變量。
可是通過傳遞變量指針就一定是傳地址調用么?看下面一個例子
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void get_str(char* p)
{
p = (char*)malloc(sizeof("abcd"));
printf("%d\n", sizeof("abcd"));
strcpy(p, "abcd");
return;
}
int main(int argc, char* argv[])
{
char* p = NULL;
get_str(p);
printf("p=%p\n", p);
puts(p);
return 0;
}
其中參數p是一個指針,程序想通過p來得到在get_str(char* p)中分配的一塊內存。但是上面的代碼并不能完成此功能。原因是程序需要在get_str(char* p)中修改main函數中的指針變量p,使其指向malloc返回的一塊內存,要想在 get_str(char* p)中修改main函數中p的值就只有把p的地址傳過去,在get_str中通過地址訪問主函數中的變量p。正確的代碼如下:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
void get_str(char** p)
{
*p = (char*)malloc(sizeof("abcd"));
printf("%d\n", sizeof("abcd"));
strcpy(*p, "abcd");
return;
}
int main(int argc, char* argv[])
{
char* p = NULL;
get_str(&p);
printf("p=%p\n", p);
puts(p);
return 0;
}
引用是C++中的語法,結合了傳地址和傳值的優點,即傳遞的是一個地址,但在形式上又沒有指針那個怪異的符合*,看上去舒服多了。
下面是一個傳引用版的swap()函數
void swap_by_ref(int& a, int& b)
{
int temp;
temp = a;
a = b;
b = temp;
}
int main(int argc, char* argv[])
{
int a=5, b=6;
swap_by_ref(a, b);
return 0;
}
總之,如果想在被調用函數中改變哪個變量的值就需要把那個變量的地址傳給被調用函數,這樣在被調用函數中通過地址就可以訪問和修改這個變量。傳值的時候會對參數進行拷貝,然后傳給被調用函數,而傳地址只是對地址進行一份拷貝,然后賦給形參,這樣在C++中如果傳遞一個比較大的對象時效率就有所區別了。對于簡單類型的變量來說傳值和傳地址在根本上是沒有區別的,都是傳遞一個數給被調用函數,而怎樣去解釋和使用這個數是我們事先約定好的。
posted on 2008-03-20 13:52
Magic 閱讀(2989)
評論(0) 編輯 收藏 引用 所屬分類:
C/C++