C#方法参数--值参数,引用参数,输出参数

值参数:

使用值参数,通过复制实参的值到形参的方式,把数据传递到方法,方法被调用的时候,系统做如下操作:

在栈中为形参分配空间;

复制实参到形参。

注意:一个值参数的实参不一定是变量,它可以是任何能够计算成相应数据类型的表达式。

在把变量用作实参之前,变量必须被赋值(除非是输出参数,这个稍后介绍),对于引用类型,变量可以设置成实际引用或者Null。

引用参数:

  • 使用引用参数时,必须在方法的申明和调用中都使用关键字ref修饰符。
  • 实参必须是变量,在用作实参前必须被赋值。如果是引用类型的变量,可以赋值为一个引用或者null值。

注意:对于值参数,系统在栈上为形参分配内存,相反对于引用参数:

形参的参数名,看起来就好象是实参变量的别名,也就是说,他们指向的是相同的内存位置。

由于形参名和实参名的行为,就好象指向相同的内存位置,所以在方法的执行过程中,对形参作的任何改变,在方法完成后依然有效(表现在实参变量上)。

注意:在方法的声明和调用上都使用关键字ref.

输出参数

输出参数用于从方法体内,把数据传出到调用代码,他们非常类似引用参数,输出参数的要求如下:

必须在声明和调用中都使用修饰符。输出参数的修饰符是out而不是ref.

和引用参数类似,实参必须是变量,而不能是其他类型的表达式。这也是有道理的,因为方法需要内存位置来保存返回值。

就像引用参数,输出参数的形参担当实参的别名。方法内对形参的任何改变,在方法执行完成后,通过实参变量都是可见的。

不同的是,输出参数的要求是:

在方法内部,输出参数在被读取之前必须被赋值。这意味着,参数的初始值是无关的,而且没有必要在方法调用之前为实参赋值;

在方法返回之前,方法内部的任何贯穿路径的可能路径,都必须为所有输出参数进行一次赋值。

时间: 2024-10-24 16:19:51

C#方法参数--值参数,引用参数,输出参数的相关文章

Java方法输出参数

在写Java代码的时候,自定义方法的时候,都会牵扯到参数问题,方法参数包括输出参数和输入参数. 下面主要说说输出参数: 1.没有输出参数的时候就直接把输出参数写成void就可以. 2.当输出参数只有一个数据的时候,直接返回输出参数直接写成输出数据的类型就行. 3.当输出多个数据且类型一致的时候,使用数组,集合等等也可以实现. 4.当输出多个数据但是数据类型不一致的时候,此时就比较麻烦.此时需要将需要返回的数据类型封装到一个类中,然后返回的值写成新封装的类的名字即可. 例如: <span styl

存储过程输出参数、返回值、返回表及C#调用

存储过程中可以定义输出变量,返回值,执行存储过程还能获得结果集.每个存储过程的默认返回值为0.下面紧接着上文 SQL Server中存储过程Stored Procedure创建及C#调用 基础上写的一个新的Stored Procedure存储过程则包含了输出参数.返回值以及select结果. USE [db] GO /****** Object: StoredProcedure [dbo].[insert_persions] Script Date: 2/25/2015 11:14:11 AM

零基础学python-17.2 参数与共享引用

这一章节我们来讨论一下参数与共享引用 承接上一章节所说的参数的传递是通过自动将对象赋值给本地变量名来实现的,其本质就是复制引用,传递对象 1.我们下面以传递不可变对象为例子: >>> b=1 >>> def test(x): print(x) print(id(x)) x=2 print(x) print(id(x)) >>> test(b) 1 497734096 2 497734112 >>> 从代码可以看出,传递过程中x赋值了1

C#形参,实参,值传递参数,引用传递参数,输出参数,参数数组的学习

1)形参 形参顾名思义就是形式上的参数,不是实际的参数,它代替实际传入方法的值.在方法体代码中代表了值本身参与运算.形参定义于参数中,它不同于方法体内局部变量,因为是一个变量,在它的作用域内不允许存在一个同名的局部变量,不管他们的类型是否相同,都是不允许出现同名的. 看下面的代码示例: 1 //这其中的strName就是一个形参也是一个变量,不允许出现同名的局部变量 2 public void SayHelloTo(string strName) 3 { 4 Console.WriteLine(

java 方法参数-值调用,引用调用问题

(博客内容来自于core java卷一) 1. xx调用:程序设计语言中方法参数的传递方式: 引用调用(call by reference):表示方法接收的是调用者提供的变量地址. 值调用(call by value):表示方法接收的是调用者提供的值. 命名调用(call by name):已经成为历史. 2. Java使用值调用,而且只有值调用.也就是说方法得到的是参数值的一个拷贝,并不是参数值本身,所以,方法不能修改传递给它的的任何参数变量本身. 看下面代码: public class te

C#值参数、引用参数和输出参数

一.值参数:在使用参数时,是把一个值传递给函数使用的一个变量.对函数中此变量的任何修改都不会影响函数调用中指定的参数.(由于函数只有一个返回值,不能用作参数的多个变量值). 二.引用参数:即函数处理的变量与函数调用中使用的变量相同,而不仅仅是值相同的变量.因此,对这个变量的任何改变都会影响用作参数的变量值.需用ref关键字指定参数.用作ref参数的变量有两个限制,由于函数可能会改变引用参数的值,所有必须在函数调用中使用“非常量”变量.其次,必须使用初始化过的变量. 三.输出参数:out关键字,指

delphi的一些语法知识 以及参数传递问题,按引用方式传递参数,按值方式传递参数

//delphi中exit,abort,break,continue 的区别 exit: 退出函数体abort: 遇到异常,安静处理,就是不显示不提示break: 退出当前循环体,包括for ,while, repeat等循环体continue: 结束循环内的本次处理,继续从循环体的开始位置继续执行 Exit 是跳出当前代码块,也就是当前函数,跳出后是要继续向下执行的(如果有后续代码). Abort 是从 EAbort 过来的,可以激发 exception,其实质就是 Abort = Raise

以指针和引用两种参数实现删除单链表L中所有值为X的结点的函数

下面是单链表的数据结构 typedef struct LNode{ ElemType data; struct LNode *next; }LNode,*Linklist; 1.以指针参数实现 void delete_x_1(LNode *head,ElemType x){//head为单链表头结点,删除结点的值为x LNode *l = head; LNode *p = head->next; while(p != null){ if(p->data == x){ l->next =

为什么赋值操作符函数的参数为const引用,返回值为引用

为什么赋值操作符函数的参数为const引用,返回值为引用 1.返回值类型 返回类型一般声明为类型的引用,并在函数结尾时返回实例自身的引用(即*this).这里主要有两个原因:(1)返回引用可以减少一次拷贝构造和析构函数导致不必要的开销,因为返回值类型不是引用,会创建一个匿名对象,这个匿名对象时个右值,获取return的值.(2)可以实现连续赋值 在例子中 b=c=a; 返回值不是引用类型也是可以的,其运算顺序 b=(c=a); c得到一个右值,再将右值赋给b,所以逻辑上没有问题的.但是如果是 (