c++函数参数类型-引用、指针、值

简介: 在编写个人函数的时候,你将会受到C++中的一条基本的原则的限制:在默认的情况下,变量只能以值传递的方式传递给函数。这句话的意思是:被传递到函数的只是变量的值,永远不是变量的本身。 例如: [cpp] view plaincopyprint? void changeVar(in...

在编写个人函数的时候,你将会受到C++中的一条基本的原则的限制:在默认的情况下,变量只能以值传递的方式传递给函数。这句话的意思是:被传递到函数的只是变量的值,永远不是变量的本身。

例如:

  1. void changeVar(int myVar,int newValue)  
  2.   
  3. {  
  4.   
  5.   myVar=newValue;  
  6.   
  7. }  
  8.   
  9. int main(){  
  10.   
  11. int myNum=20;  
  12.   
  13. changeVar(myNum,90);  
  14.   
  15. std::cout<<myNum<<endl;  
  16.   
  17. return 0;  
  18.   
  19. }  
void changeVar(int myVar,int newValue) { myVar=newValue; } int main(){ int myNum=20; changeVar(myNum,90); std::cout<<myNum<<endl; return 0; }


结果为 20

出现这种情况的原因是:在调用changeVar()函数时,程序只是把main()函数中的myNum变量的值赋值给了changeVar()函数中的myVar变量,它们是两个不同的变量。事实上,changeVar()函数完全不知道在main()函数中还存在一个myNum的变量,甚至连它的名字都不知道。

解决方法:

通过使用地址和指针

绕开值传递问题的第一个方法是向函数传递变量的地址而不是它的值。

  1. int main()  
  2.   
  3. {  
  4.   
  5. int myNum=20;  
  6.   
  7. changeVar(&myNum,90);  
  8.   
  9. }  
int main() { int myNum=20; changeVar(&myNum,90); }


当然,changeVar()函数也要相应的改动。

  1. void changeVar(int* myVar,int newValue){  
  2.   
  3. *myVar=newValue;  
  4.   
  5. }  
void changeVar(int* myVar,int newValue){ *myVar=newValue; }


现在可以得到预期的结果90了。

这种交换在很多的排序算法里都要用到。

提示:有时候,向函数传递地址是让函数接收一个复杂数据类型的唯一方法。

 

引用传递方式向函数传递参数

既然像这样使用地址是一种很好的思路,让这个概念更加完善岂不是更好?如果事先知道某个函数只能接受一个地址,能不能按照某种套路来编写有关的代码以便在调用该函数时不需要使用特殊的语法呢?

引入引用传递方式输入参数。

引用的定义

int a = 100;

int& b = a;

b = 1000;

考察: (1)&a&b的关系? (2) a=?

b现在是a的一个别名! a=1000;

1)引用必须在声明时立即初始化,不允许空引用

2)引用一旦初始化,就不能再引用其它数据

3)引用和被引用的变量实际上代表同一个内存的数据 

引用的主要功能

传递函数的参数和返回值.C++中常用的方式有三种

值传递,指针传递和引用传递

引用传递的性质象指针传递,书写形式象值传递,

理由:如果只需要借用一下别名,就没必要用指针,.

void changeVar(int &myVar,int newValue);

这个函数第一个输入的参数不是一个指针,它是那个将被传递给这个函数的原始变量的一个别名。在changeVar()函数里对这个参数变量进行的任何操作都将反映在changeVar()函数外的那个原始变量身上。这意味着changeVar()函数与原来的一样。

void changeVar(int myVar,int newValue){

  myVar=newValue;

}

这使得这个函数更容易被调用----只需要提供一个变量名;

int main(){

int myNum=20;

changeVar(myNum,90);

}

这比值传参语法上更简单了。

引用传递”方式把参数值传递给一个函数是C++的新增功能,这可以让函数的调用语法更加简单清晰。

提示:1.在定义函数时,还可以让它以引用传递方式而不是以值传递方式返回: int &myFuntion();

           2.除了可以改变有关变量的值,引用传递方式的另一个好处是它的开销相对要小一些:因为不需要在函数里创建临时变量来容纳那些值,程序的内存占用量当然会小一些。

           3.如果想获得引用传递方式带来的性能改善,但不想改变某个变量的值,可以把相应的输入参数定义为一个常量:

 void myFunc(const int &myNum);

通过这样定义的函数,可以把具体的参数直接传递给它:myFunc(7);

 

 

目录
相关文章
|
23天前
|
安全 编译器 C++
【C++11】可变模板参数详解
本文详细介绍了C++11引入的可变模板参数,这是一种允许模板接受任意数量和类型参数的强大工具。文章从基本概念入手,讲解了可变模板参数的语法、参数包的展开方法,以及如何结合递归调用、折叠表达式等技术实现高效编程。通过具体示例,如打印任意数量参数、类型安全的`printf`替代方案等,展示了其在实际开发中的应用。最后,文章讨论了性能优化策略和常见问题,帮助读者更好地理解和使用这一高级C++特性。
38 4
|
1天前
|
存储 程序员 C++
深入解析C++中的函数指针与`typedef`的妙用
本文深入解析了C++中的函数指针及其与`typedef`的结合使用。通过图示和代码示例,详细介绍了函数指针的基本概念、声明和使用方法,并展示了如何利用`typedef`简化复杂的函数指针声明,提升代码的可读性和可维护性。
8 0
|
1月前
|
存储 编译器 Linux
【c++】类和对象(上)(类的定义格式、访问限定符、类域、类的实例化、对象的内存大小、this指针)
本文介绍了C++中的类和对象,包括类的概念、定义格式、访问限定符、类域、对象的创建及内存大小、以及this指针。通过示例代码详细解释了类的定义、成员函数和成员变量的作用,以及如何使用访问限定符控制成员的访问权限。此外,还讨论了对象的内存分配规则和this指针的使用场景,帮助读者深入理解面向对象编程的核心概念。
81 4
|
2月前
|
存储 安全 编译器
在 C++中,引用和指针的区别
在C++中,引用和指针都是用于间接访问对象的工具,但它们有显著区别。引用是对象的别名,必须在定义时初始化且不可重新绑定;指针是一个变量,可以指向不同对象,也可为空。引用更安全,指针更灵活。
|
2月前
|
程序员 C++ 容器
在 C++中,realloc 函数返回 NULL 时,需要手动释放原来的内存吗?
在 C++ 中,当 realloc 函数返回 NULL 时,表示内存重新分配失败,但原内存块仍然有效,因此需要手动释放原来的内存,以避免内存泄漏。
|
2月前
|
存储 前端开发 C++
C++ 多线程之带返回值的线程处理函数
这篇文章介绍了在C++中使用`async`函数、`packaged_task`和`promise`三种方法来创建带返回值的线程处理函数。
70 6
|
2月前
|
C++
C++ 多线程之线程管理函数
这篇文章介绍了C++中多线程编程的几个关键函数,包括获取线程ID的`get_id()`,延时函数`sleep_for()`,线程让步函数`yield()`,以及阻塞线程直到指定时间的`sleep_until()`。
30 0
C++ 多线程之线程管理函数
|
2月前
|
存储 C++
c++的指针完整教程
本文提供了一个全面的C++指针教程,包括指针的声明与初始化、访问指针指向的值、指针运算、指针与函数的关系、动态内存分配,以及不同类型指针(如一级指针、二级指针、整型指针、字符指针、数组指针、函数指针、成员指针、void指针)的介绍,还提到了不同位数机器上指针大小的差异。
56 1
|
2月前
|
编译器 C语言 C++
C++入门6——模板(泛型编程、函数模板、类模板)
C++入门6——模板(泛型编程、函数模板、类模板)
53 0
C++入门6——模板(泛型编程、函数模板、类模板)
|
26天前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
92 13