ref 和out传参的不同

简介:

今天又遇到这个问题了,问了问同事,他说最近面试的时候,也问道他了,于是给我讲了讲,现在大概是记住了,记录下来,以备自用。

首先是看下面的code例子

 

string b= "bb";
Public  void A( ref b)
{
// to do
}

string d;
Public  void C( out d)
{
d= "jjjjj";
//  to  do 
}

 

方法A是引用参数b但是b必须先定义并且在方法之前进行初始化,在引用的时候就像一般方法处理即可;方法B是先定义变量d此时不需要初始化,在引用此变量的方法中需要进行初始化,然后可在方法内做任何操作,个人理解方法C等同于下列代码:

 

string d;
Public  string C( string d)
{
d= " ddd ";
return d;
}

所有out是在传进未初始化的参数后在内部做一定的处理,并返回定义的类型。ok game over!



本文转自shenzhoulong  51CTO博客,原文链接:http://blog.51cto.com/shenzhoulong/677047,如需转载请自行联系原作者

相关文章
|
8月前
|
C#
C#系列之ref和out的区别
C#系列之ref和out的区别
263 0
|
JSON JavaScript 数据格式
Vue3.0实现todolist之路由传参(query模式传参和params传参)
Vue3.0实现todolist之路由传参(query模式传参和params传参)
111 1
C#基础⑧——方法(函数、重载、out、ref)
比喻成职能。比喻成一个生产自行车老板,一个地方专门放螺丝,一个地方专门放轮,一个地方专门放车链子,需要组装什么就从那个仓库里面拿就行了。各司其职。
|
C++
c++中ref的作用
c++中ref的作用
161 0
|
缓存
在 store 中定义 getter 传参
注意,getter 在通过方法访问时,每次都会去进行调用,而不会缓存结果。
107 0
|
存储 JavaScript 前端开发
ref绑定dom的三种写法
ref绑定dom的三种写法
ref绑定dom的三种写法
|
前端开发 JavaScript 开发者
为 class 创建的组件传递 props 参数并直接使用 this.props 来访问|学习笔记
快速学习为 class 创建的组件传递 props 参数并直接使用 this.props 来访问
162 0
为 class 创建的组件传递 props 参数并直接使用  this.props 来访问|学习笔记
|
JavaScript
ref属性
ref属性
117 0
|
JavaScript 前端开发
为class创建的组件传递props参数并直接使用this.props来访问
为class创建的组件传递props参数并直接使用this.props来访问
为class创建的组件传递props参数并直接使用this.props来访问