一、理论部分

C++中函数形参主要分为两类,如图1所示,

        图1

总结:

一、当函数参数为非引用形参时,传进函数体内的是实参的拷贝,(注意,对于基本类型而言,拷贝的是实参的值,对于指针而言拷贝的是实参的地址)

(1)若形参为非const的基本类型,则即可接收const实参,也可接收非const实参。只是在函数体内修改形参的值不影响实参的值。

因为对于基本类型的形参而言,传递进函数体的是实参拷贝的值,而不是实参本身,所以在函数体内修改实参的值不影响实参。

(2)若形参为非const的指针类型,则即可接收const实参,也可接收非const实参。在函数体内修改形参的值会影响实参的值。

因为对于指针类型的形参而言,传递近函数体的是实参指针地址的拷贝,形参指针和实参指针指向同一个地址,修改实参指针所指向的值会影响实参指针的所指向的值。

(3)若形参为const的基本类型,则即可接收const实参,也可接收非const实参。只是在函数体内不能修改形参的值。

(4)若形参为const的指针类型,则只能接收const类型的指针实参,不能接收非const的指针实参。

const指针的初始化规则:可以将指向const对象的指针指向非const对象,不可以将指向为非const对象的指针指向const对象。

二、当函数为引用形参时,传递近函数体内的是实参本身,因为引用就是变量的别名,改变引用的值同时会影响变量的值。

(1)引用形参是实参的别名,可以达到修改实参的目的。

(2)引用形参可以额外的返回值。

(3)对于函数体内不修改形参值的情况,应该将形参设置为const &,即const引用,可减少值的拷贝赋值。

(4)指向指针的引用若在函数体进行改变,则改变的是指针所指向对象的值。

二、代码片段如下:

代码片段1:
int add_1(int x,int y)
{
return x+y;
} int add_2(const int x,const int y)
{
//x++;//error,const参数不能修改
return x+y;
}
int main()
{
int a=1,b=2;
const int m=9;
const int n=8;
add_1(a,b);//ok
add_1(m,n);//ok
add_2(m,n);//ok
add_2(a,b); //ok
return 0;
}

片段1中得出的结论:

当形参类型为基本数据类型时,非const形参可以接收const实参,同时也可以接收非const实参;
当形参类型为基本数据类型时,const形参可以接收const实参,同时也可以接收非const实参。
当形参为const参数时,不能在函数体内修改该形参的值。
 
代码片段2:
void add_1(int *a)
{
*a = *a +1;
} void add_2(const int *a)
{
//*a = *a +2;//error,因为该指针指向const常量,不能修改常量的值
} int add_3(const int *a)
{
return *a +2;
}
int main()
{
int a = 1,b=2,c=3;
const int a2 = 10;
const int b2 = 20;
const int c2 = 30;
add_1(&a);//ok
// add_1(&a2);//error add_3(&a);//ok
add_3(&a2);//ok
return 0;
}

片段2中得出的结论:

当形参为const指针时,不能修改指针所指向的值。
当形参为非const指针时,只能接收非const指针实参,不能接收const指针实参。
当形参为const指针时,既可以接收非const指针实参, 也可以接收const指针实参。
 
代码片段3:
//引用形参,是实参的别名,修改的是实参的值
void add(int &x)
{
x = x +1 ;
}
//引用形参相当于额外的返回值 void fuc2(int i,int j,int &jf,int &jf2,int &cf,int &cf2)
{
jf = i + j;
jf2 = i - j;
cf = i * j;
cf2 = i /j;
} //在函数体内不需要修改的形参都应该设置为const &,即const引用 //指向地址的 引用
void cund(int *&x,int *&y)
{
int *temp = y;
y = x;
x = temp;
}
int main()
{
int i = 9;
cout<<"before "<<i<<endl;//9
add(i);
cout<<"after "<<i<<endl;//10
int j = 20; int v1,v2,v3,v4;
fuc2(i,j,v1,v2,v3,v4); cout<<"加法结果:"<<v1<<endl;
cout<<"减法结果:"<<v2<<endl;
cout<<"乘法结果:"<<v3<<endl;
cout<<"除法结果:"<<v4<<endl; cout<<"==========================="<<endl;
int *ptri = &i;// ptri指针指向i
int *ptrj = &j;// ptrj指针指向j
cout<<"交换之前:"<<i <<" , "<<j<<endl;          //i = 10 j = 20
cout<<"交换之前-指针:"<<*ptri <<" , "<<*ptrj<<endl;  //*ptri = 10 *ptrj = 20
cund(ptri,ptrj);//交换的是指针的值,不是i,j的值
cout<<"交换之后:"<<i <<" , "<<j<<endl;          //i = 10 j = 20
cout<<"交换之后-指针:"<<*ptri <<" , "<<*ptrj<<endl;  //*ptri = 20 *ptrj = 20
return 0;
}

  

C++学习基础五之函数参数——形参的更多相关文章

  1. Python学习笔记五,函数及其参数

    在Python中如何自定义函数:其格式为 def 函数名(函数参数): 内容

  2. C++Premer Plus学习(五)——函数探幽

    一.内联函数 1.优点: 内联函数就是比较省资源,然后一般就是将简短,使用频率高的函数作为内联函数会比较合适. 2.一个demo #include "stdafx.h" #incl ...

  3. C++学习基础十六-- 函数学习笔记

    C++ Primer 第七章-函数学习笔记 一步一个脚印.循序渐进的学习. 一.参数传递 每次调用函数时,都会重新创建函数所有的形参,此时所传递的实参将会初始化对应的形参. 「如果形参是非引用类型,则 ...

  4. 【Unity|C#】基础篇(4)——函数参数类型(值参/ref/out/params)

    [学习资料] <C#图解教程>(第5章):https://www.cnblogs.com/moonache/p/7687551.html 电子书下载:https://pan.baidu.c ...

  5. python学习第五天 ----- 函数

    1. 内置函数 例如: print, round 2.自定义函数: 通过def来定义 def funcname(parameter_list): pass ⑴.参数parameter_list可以没有 ...

  6. Linux基础(五) Shell函数

    Shell 函数 linux shell 可以用户定义函数,然后在shell脚本中可以随便调用. shell中函数的定义格式如下: [ function ] funname [()] { action ...

  7. Python基础:10函数参数

    局部命名空间为各个参数值创建了一个名字,一旦函数开始执行,就能访问这个名字了. 在函数调用时,有非关键字参数和关键字参数之分,非关键字参数必须位于关键字参数之前. 在函数定义时,严格的顺序是:位置参数 ...

  8. 【C#基础概念】函数参数默认值和指定传参和方法参数

    函数参数默认值和指定传参 最近在编写代码时发现介绍C#参数默认值不能像PL/SQL那样直接设置default,网上也没有太多详细的资料,自己琢磨并试验后整理成果如下: C#允许在函数声明部分定义默认值 ...

  9. Python学习总结18:函数 参数篇

    1. 判断函数是否可调用 >>> import math >>> x = 1 >>> y = math.sqrt >>> cal ...

随机推荐

  1. plist文件真机写入方法

    http://blog.csdn.net/mydo/article/details/50290219  转 但是这对真机不管用,因为在真机环境下,App在Xcode中的Resources文件夹都是不可 ...

  2. 数据库对象映射为java对象,不使用框架

    方法: public static <T> List<T> processResultSetToList(ResultSet rs, Class<T> clazz) ...

  3. Counting Sequences_线段树***

    Description For a set of sequences of integers{a1,a2,a3,...an}, we define a sequence{ai1,ai2,ai3...a ...

  4. CI框架引入外部css和js文件

    首先在项目根目录下建立assets文件夹,在这个文件夹下再建立css和js文件夹分别放置css和js文件 然后,在项目根目录下建立.htaccess文件 内容如下: RewriteEngine on  ...

  5. UVA 572

    这是一道纯正的深度优先搜索题目. 题目要求在有多少个不同的块,而不同块的定义则是,一个块中的任意一点和l另一个块中的任意一点不会相连,而相连的定义则是 在横向.纵向和对角线上相连. #include& ...

  6. IOS5中的Safari不兼容Javascript中的Date问题

    在IOS5以上版本(不包含IOS5)中的Safari浏览器能正确解释出Javascript中的 new Date('2016-06-07') 的日期对象. 但是在IOS5版本里面的Safari解释ne ...

  7. unity, 由scriptableObject创建.asset

    由继承自scriptableObject的类X创建.asset文件. 假设类X的定义为: [System.Serializable] public class X : ScriptableObject ...

  8. Node.js知识点

    1. 入口文件app.js里的路由,按顺序执行: 2.

  9. 7个混合式HTML5移动开发框架

    在这个时间开始学习移动开发真是最好不过了,每个人应该都有一些移动应用的创意,而且你并不需要任何的原生应用编程经验,你只需要一些HTML的相关知识,懂一些CSS和JavaScript就够了.如果你总听别 ...

  10. Storm Topology及分组原理

    Storm的通信机制,需要满足如下一些条件以满足Storm的语义. 1.建立数据传输的缓冲区.在通信连接没有建立之前把发送的数据缓存起来.数据发送方可以在连接建立之前发送消息,而不需要等连接建立起来, ...