C++函数参数-值,指针,引用

本文转载自SurpassLi的博文:http://www.cnblogs.com/lidabo/archive/2012/05/30/2525837.html,修改了部分代码和贴图,如有侵犯版权请与我联系删除。      

    以“ 值传递”方式向函数传递参数

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

例如:

void changeValue(int originalValue,int newValue){
  originalValue = newValue;
}  

int main(){
  int myNum=20;
  changeValue(myNum,90);
  std::cout<<myNum<<endl;  

  return 0;
}

结果为 20;

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

解决方法:通过使用地址和指针绕开“值传递”问题的第一个方法是向函数传递变量的地址而不是它的值。

    以“指针传递”方式向函数传递参数

void changeValueViaPointer(int* originalValue,int newValue){
  *originalValue = newValue;
}  

int main(){
  int myNum=20;
  changeValueViaPointer(&myNum,90);
  std::cout<<myNum<<endl;  

  return 0;
}

现在可以得到预期的结果90了。这种交换在很多的排序算法里都要用到。提示:有时候,向函数传递地址是让函数接收一个复杂数据类型的唯一方法。

以“引用传递”方式向函数传递参数

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

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

引用的定义

int a = 100;

int& b = a;

b = 1000;

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

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

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

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

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

引用的主要功能

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

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

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

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

void changeValueViaQuote(int &myVar,int newValue);

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

void changeValueViaQuoter(int & myVar,int newValue){

  myVar=newValue;

}

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

int main(){

  int myNum=20;

  changeValueViaQuoter(myNum,90);

}

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

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

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

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

3.如果想获得“引用传递”方式带来的性能改善,但不想改变某个变量的值,可以把相应的输入参数定义为一个常量:void myFunc(const int &myNum); 通过这样定义的函数,可以把具体的参数直接传递给它:myFunc(7);

传参方式 int a = 10; 使用方法 结果
传值
void changeData(int b) {

b += 10;

}

changeData(a); a == 10
传地址
void changeAddrress(int * b)

{

*b += 10;

}

changeAddrress(&a) a == 20
传引用
void changeQuoter(int & b)

{

b += 10;

}

changeQuoter(a); a == 20

C++函数参数-值,指针,引用,布布扣,bubuko.com

时间: 2024-10-10 16:44:48

C++函数参数-值,指针,引用的相关文章

C++ Primer 学习笔记_17_从C到C++(3)--引用、const引用、引用传递、引用作为函数返回值、引用与指针区别

欢迎大家阅读参考,如有错误或疑问请留言纠正,谢谢 一.引用 1.引用是给一个变量起别名 变量: 名称 空间 引用: 引用不是变量 引用仅仅是变量的别名 引用没有自己独立的空间 引用要与它所引用的变量共享空间 对引用所做的改变实际上是对它所引用的变量的改变 引用在定义的时候必须要进行初始化 引用一经初始化,不能重新指向其他变量 2.定义引用的一般格式: (1)类型  &引用名 = 变量名: (2)例如: int a=1; int &b=a; // b是a的别名,因此a和b是同一个单元 (3)

C++中函数模板template和函数参数为指针,且有返回值的结合使用

1 #include<iostream> 2 using namespace std; 3 // 利用模板函数计算一个表达式 4 template<class Type> 5 Type Abc(Type a,Type b,Type c) 6 { 7 return a+b+c; 8 } 9 // 利用引用参数指针计算一个表达式 10 template<class Type> 11 Type ABC(Type *a,Type *b,Type *c) 12 { 13 retu

C/C++语言参数传递----函数/方法 参数的指针引用传递

int m_value = 1; void func(int *p) { p = &m_value; } int main(int argc, char *argv[]) { int n = 2; int *pn = &n; cout << *pn << endl; func(pn); cout << *pn <<endl; return 0; } 看一下输出结果 22 -------其实上面这些例子,看一百次,我个人觉得,也看不出实际意义

理解-加号重载要使用全局函数+返回值非引用

一.C++中的加号重载使用全局函数的一个有点是可以使用级联的方式进行加法操作. Fraction a,b,c,d,e; A=b+c+d+e; 若为成员函数 1.返回的b的this指针分别作用于后面的变量,因此是对b的修改: 2.如果返回一个新的变量,上面的级联的问题似乎可以解决. 3.问题在于如果存在隐式类型转换,且第一个参数为需要转化的类型时,可能找不到该定义的成员函数,因此使用全局的方式可以便面这个问题 二.返回值需要时一个值,而不是引用 从一个局部函数返回引用,可以考虑两种情况. 1.如果

函数返回值与引用

一段代码 #include <iostream> float temp; ? ? ? ?//全局变量,驻留在内存的data区 float fn1(float r){ ? ?temp = r*r*3.14; ? ?return temp } float&?fn2(float r){ ? ?temp= ?r*r*3.14; ? ?return temp; } int main(){ ???float a=fn1(5.0); //1 ? ?float& b=fn1(5.0); //2

函数是对象,函数名值指针

如题,函数与函数名的关系就和对象与对象指针关系是一样的,如何理解呢? function sum(a,b){ return a+b; } 上述代码定义了一个名为sum的函数,其函数名sum与函数主体的关系如下: 和对象与对象指针的关系一样,一个函数可以有多个名字. function sum(a,b){ return a+b; } alert(sum(10,10));//20 var anotherSum = sum; alert(anotherSum(10,10));//20 上述代码将函数指针s

const修饰函数参数 const修饰函数返回值 const修饰成员函数

看到const 关键字,C++程序员首先想到的可能是const 常量.这可不是良好的条件反射.如果只知道用const 定义常量,那么相当于把火药仅用于制作鞭炮.const 更大的魅力是它可以修饰函数的参数.返回值,甚至函数的定义体. const 是constant 的缩写,"恒定不变"的意思.被const 修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性.所以很多C++程序设计书籍建议:"Use const whenever you need". 1

const 小结: 做函数参数,做函数返回值,以及const函数

做函数参数 : 例如 fun(const int * i)参数i的值不能在fun()函数执行的过程中被修改,它将一直保持调用此函数时传入的值.如果试图修改i值的语句在fun()函数中出现,将导致程序无法编译,这样对参数i起到保护作用. 注:const 通常用来限制函数的指针参数,引用和数组参数,而一般形式的参数因为形参和实参本不是同一内存单元的变量,所以对形参的修改不会影响实参,因此也没有必要限制函数体不能对参数进行修改.  做函数返回值 : 函数返回值为 const 只有用在函数返回为引用的情

Day8 函数指针做函数参数

课堂笔记 课程回顾 多态 virtual关键字 纯虚函数 virtual func() = 0; 提前布局vptr指针 面向接口编程 延迟绑定 多态的析构函数的虚函数. 多继承的二义性 . 重载 重写 重定义. 实现多态的理论基础:函数指针做函数参数. vptr指针与虚函数表. 构造函数不应为虚函数 多态会降低程序的执行速度.不建议所有的函数都是虚函数. 多态时的指针步进. 多继承在项目开发中使用的比较少. linux从2.4内核升级到2.6的时候,做到了电源可以热插拔,提前将电源驱动的接口规划

C++学习基础五之函数参数——形参

一.理论部分 C++中函数形参主要分为两类,如图1所示, 图1 总结: 一.当函数参数为非引用形参时,传进函数体内的是实参的拷贝,(注意,对于基本类型而言,拷贝的是实参的值,对于指针而言拷贝的是实参的地址) (1)若形参为非const的基本类型,则即可接收const实参,也可接收非const实参.只是在函数体内修改形参的值不影响实参的值. 因为对于基本类型的形参而言,传递进函数体的是实参拷贝的值,而不是实参本身,所以在函数体内修改实参的值不影响实参. (2)若形参为非const的指针类型,则即可