在 c++++ 中,传递函数参数有三种方式:值传递、引用传递和指针传递。值传递传递参数值的副本,对副本的更改不影响原始参数。引用传递传递原始参数的引用,对引用的任何更改都会影响原始参数。指针传递传递参数的指针,对指针的更改也会影响原始参数。
C++ 中函数参数传递:值传递、引用传递和指针传递
在 C++ 中,向函数传递参数时,需要了解三种不同的传递机制:值传递、引用传递和指针传递。
值传递
立即学习“C++免费学习笔记(深入)”;
值传递是最基本的传递机制。当使用值传递时,函数会得到参数值的副本。这意味着对该副本所做的任何更改都不会影响原始参数。
void print_value(int x) { x = 10; // 更改副本的值}int main() { int y = 5; print_value(y); // y 的值为 5 cout << y; // 仍然为 5}登录后复制引用传递
引用传递通过将参数的引用传递给函数来提高效率。通过引用,函数可以直接访问原始参数,而不是其副本。这就意味着对引用所做的任何更改都会影响原始参数。
void print_reference(int& x) { x = 10; // 更改原始参数的值}int main() { int y = 5; print_reference(y); // y 的值为 5 cout << y; // 输出为 10}登录后复制指针传递
指针传递与引用传递类似,但它通过将参数的指针传递给函数来实现。指针是一种引用变量地址的变量。与引用类似,通过指针对原始参数所做的任何更改都会影响原始参数。
void print_pointer(int* x) { *x = 10; // 解引用指针并更改原始参数的值}int main() { int y = 5; print_pointer(&y); // 传递 y 的地址 cout << y; // 输出为 10}登录后复制实战案例:数组排序
让我们使用不同的传递机制来编写一个排序数组的函数。
值传递
立即学习“C++免费学习笔记(深入)”;
void sort_by_value(int arr[], int size) { // 创建一个 arr 的副本并进行排序 int* sorted_arr = new int[size]; memcpy(sorted_arr, arr, sizeof(int) * size); sort(sorted_arr, sorted_arr + size);}登录后复制引用传递
void sort_by_reference(int arr[], int size) { sort(arr, arr + size); // 直接对原始数组进行排序}登录后复制指针传递
void sort_by_pointer(int* arr, int size) { sort(arr, arr + size); // 直接对原始数组进行排序}登录后复制在这个案例中,引用传递和指针传递比值传递更有效率,因为它们直接对原始数组进行操作,避免了创建副本的开销。
以上就是C++ 中函数参数传递:值传递、引用传递和指针传递的详细内容!