参数传递
每次调用函数时,都会重新创建该函数所有的形参,此时所传递的实参将会初始化对应的形参。
形参的初始化与变量的初始化一样,如果形参具有非引用类型,刚复制实参的值,如果形参为引用类型,则它是实参的别名。
如需保护指向的值,则形参需定义为指向const对象的指针。
可以将指向const对象的指针初始化为指向非const对象,但不可以让指向非const对象的指针指向const对象。(细细品味)
1、当需要在函数中修改实参的值时
2、当需要大型数据作为实参传入时,所需要的时间和空间代价往往过大。
3、当没有办法实现对象复制时。
1、通过引用形参返回额外的信息、
2、利用const引用避免复制(这话写的差点让我晕了,后面解释)
如果使用引用形参的唯一目的是避免复制实参,则应将形参定义为const引用(为什么?)
定义为const引用,可以避免修改实参,而只使用了形参的避免复制,我想这也就是这个标题的由来吧。
3、更灵活的指向const的引用
应该将不需要修改的引用形参定义为const引用。
4、传递指向指针的引用
每次调用函数时,都会重新创建该函数所有的形参,此时所传递的实参将会初始化对应的形参。
形参的初始化与变量的初始化一样,如果形参具有非引用类型,刚复制实参的值,如果形参为引用类型,则它是实参的别名。
非引用实参表示对应实参的局部副本。对这类形参的修改仅仅改变了局部副本的值。一旦函数执行结束,这些局部变量的值也就没有了。
如需保护指向的值,则形参需定义为指向const对象的指针。
可以将指向const对象的指针初始化为指向非const对象,但不可以让指向非const对象的指针指向const对象。(细细品味)
非引用的const类型,由于还是以副本的形式传递,因此传递进函数的对象既可以是const对象,也可以是非const对象,但是仍被认为是普通类型来使用。
1、当需要在函数中修改实参的值时
2、当需要大型数据作为实参传入时,所需要的时间和空间代价往往过大。
3、当没有办法实现对象复制时。
解决办法:将形参定义为引用或指针类型。
从C语言背景到C++程序员习惯通过传递指针来实现对实参的访问,在C++中,使用引用形参则更安全和更自然。
1、通过引用形参返回额外的信息、
2、利用const引用避免复制(这话写的差点让我晕了,后面解释)
如果使用引用形参的唯一目的是避免复制实参,则应将形参定义为const引用(为什么?)
定义为const引用,可以避免修改实参,而只使用了形参的避免复制,我想这也就是这个标题的由来吧。
3、更灵活的指向const的引用
应该将不需要修改的引用形参定义为const引用。
4、传递指向指针的引用