C++中的值传递,引用传递及指针传递

操作方法

  • 01

    C++中的值传递,引用传递及指针传递C++的值传递,引用传递,指针传递这些概念一贯是迷惑C++程序员,我一贯也没有一个能说清他们之间的联络通过一个简略的实例,或许说浅显的说法,找了一些有关资料,和自已的自个感受,简略介绍一下。 c++中传递参数的办法有三种:传参数的值(称为值传递,简称传值),传参数的地址(称为地址传递,简称为传址),和引用传递(简称为传引用),相应的函数也便是传值调用,传址调用和传引用调用 函数定义时参数表中的参数称为形式参数,简称形参,函数调用时参数表中的参数称为实习参数,简称实参,实参和形参之间的数据传递称为形实联络,通常情况下c++言语是传值调用,传值调用是单向的,即参数的值只能由实参传递给形参,而不能反过来由形参传递给值参,也便是说,从被调用函数的角度来看,参数的值只能传入不能传出。传值调用时实参可所以具体的数值、已经有值的变量和可求值的表达式,由于数值和变量都是表达市的一种,因此,传值调用时实参本质上是表达式。当函数被调用时,系统首要对实参表达式球值,然后将值传递给形参,换过一种思路,传值调用时,形参实习上是实参的一份仿制,所以传递时不会改动外部变量实参的值, 假定声明一个变量int n=1;那么他在内存中的存储,我们可以这样来知道,第一:内存中1是指变量n的值,存储这个值的地址我们把他称为1的内存地址,也便是指针地址,n是他的名字,或许我们把他叫做1的大名,别的我们可以给他起一个别的名字,叫做奶名,也叫别号,由于大名和小别都是指向同一个值,所以改动大名的值也便是改名奶名的值,奶名是大名的一种引用,理清了上面这些含义,我们就来举个比方. int m; int &n=m; n是m的引用reference,m是被引用物referent。n相当于m的别号, 引用的一些规则如下: (1)引用被创建的一同有必要被初始化(指针则可以在任何时候被初始化)。 (2)不能有NULL引用,引用有必要与合法的存储单元有关(指针则可所以NULL)。 (3)一旦引用被初始化,就不能改动引用的联络(指针则可以随时改动所指的方针)。 引用的主要功能是传递函数的参数和返回值。 C++言语中,函数的参数和返回值的传递办法有三种:值传递、指针传递和引用传递. 以下是“值传递”的示例程序。 由于Func1函数体内的x是外部变量n的一份仿制,改动x的值不会影响n,所以n的值仍然是0。 #include using namespace std; func(int x); void main(){ int n=0; func(n); cout< } func(int x){ x = x + 10; } C++中的值传递,引用传递及指针传递(2)以下是“指针传递”的示例程序。 由于Func2函数体内的x是指向外部变量n的指针,改动该指针的内容将致使n的值改动,所以n的值成为10。 #include using namespace std; func(int *x); void main(){ int n=0; func(&n); cout< } func(int *x){ *x = *x + 10; } 以下是“引用传递”的示例程序。 由于Func3函数体内的x是外部变量n的引用,x和n是同一个东西,改动x等于改动n,所以n的值成为10。 #include using namespace std; func(int &x); void main(){ int n=0; func(n); cout< } func(int &x){ x = x + 10; }

(0)

相关推荐

  • 解决Excel表格中的“值不可用”错误标识"#N/A"问题的方法

    excel出现值不可用错误怎么办?在EXCEL工作表中使用公式和函数对数据进行运算的时候,会出现“值不可用”错误标识"#N/A",影响表格的美观.那么,在EXCEL中,出现#N/A ...

  • 怎么借助excel表格将word文档中重复值删除掉

    当我们的word文档中有重复值的话,有很多种方法可以删除.今天小编要介绍的是怎么借助excel表格将word文档中重复值删除掉.具体如下:1.我们在电脑中打开一份word文档,进入主界面之后选中需要删 ...

  • 怎么利用word文档中的邮件功能引用excel数据

    今天给大家介绍一下怎么利用word文档中的邮件功能引用excel数据的具体操作步骤.1. 首先打开电脑,找到想要引用的excel表格,双击打开:2. 然后将excel表格的标题复制粘贴到word文档中 ...

  • Excel怎么通过公式获取单元格数据中第五大值

    Excel是现在十分常用的一款办公软件,有些新用户不知道怎么通过公式获取单元格数据中第五大值,接下来小编就给大家介绍一下具体的操作步骤.具体如下:1. 首先第一步根据下图所示,打开电脑中的Excel文 ...

  • java如何向String[]中添加值

    在平时的java开发中,经常会操作数组,那么,java中怎么像数组中添加元素呢,java怎么向String[]中添加值呢,下面本文就介绍一下. 操作方法 01 在java中,向String[]中添加元 ...

  • excel中如何使用绝对引用

    excel中如何使用绝对引用,这里,让小编给大家大概的介绍一下,让大家知道是怎么回事. 操作方法 01 首先我们打开一个excel表格作为例子. 02 我们看一下引用的方法,在旁边的单元格内输入图中的 ...

  • Excel中时间差值如何计算

    Excel中我们有时候会用到计算时间差值,方法并不是一种,下面介绍一下计算时间差值的简便方法: Excel中时间差值如何计算 操作方法 01 如图要计算开始时间和结束时间差,我们输入"23: ...

  • 怎么在win10电脑中设置按Ctrl时显示鼠标指针的位置

    如果我们在Win10中没有进行一些设置,那么在移动鼠标的时候,有可能看不到指针位置,想要设置显示指针位置的话,该怎么操作呢?今天就跟大家介绍一下怎么在win10电脑中设置按Ctrl时显示鼠标指针的位置 ...

  • 如何在Excel中双条件查找引用交叉单元格的值?

    如下图所示B2:D10单元格区域为某公司不同职位的员工的培训课程可以获得提成比例,要在I列求出对应的提成比例可以使用经典的INDEX+MATCH公式. 操作方法 01 在I2单元格先用公式 =MATC ...