编程小知识,在C#中如何让一个方法返回多个值
在日常的程序编写中,我们可能会遇到这样的需求!就是让一个方法,返回多个值,或者多种类型的值!
这类问题其实比较好解决,方案有很多种!本次讲解下,在C#语言中,此类问题的解决方案!
如果长期从事C#语言开发工作的小伙伴们,对于这两个关键字,肯定再熟悉不过了!
在这里温故而知新一波儿,为了新入坑的小伙伴们着想一下!
ref关键字( Reference的缩写 ): “The ref keyword indicates a value that is passed by reference.” 顾名思义就是通过引用来传递参数。
接下来看下ref关键字的用法:
out关键字:“As a parameter modifier, which lets you pass an argument to a method by reference rather than by value.”参数修饰符,允许您通过引用而不是通过值将参数传递给方法。
接下来看下out关键字的用法:
ref与out关键字,总结一下:
实际上无论是ref,还是out,作用都是将值类型按引用类型传递,都是服务于值类型的关键字。
他们的区别是:ref关键字要求,参数必须先初始化,方法内可以不用对ref修饰参数赋值操作。而out关键字则要求,参数可以不初始化,但方法内必须存在out修饰参数的赋值操作。
究其原因:out关键字是在方法内,完成分配内存地址操作。而ref则是将地址传入到方法中。
ref关键字使用错误的案例:
out关键字使用错误案例:
C#进入到异步时代,异步多线程编程模型,在如今的.NET技术体系中,可以说遍地开花般的存在。
这种异步编程模型,也让.NET CORE有了更优秀的性能,无论是吞吐量,还是程序执行性能,都有了质的飞跃。
回顾下异步方法定义三部曲:
1:async后缀,见名知意。
2:返回类型只能为void、Task、Task ,推荐2、3。
3:参数不能用out、ref关键字修饰。
此时的 “小麻烦” 来了,异步虽好,但是无法使用上述讲到的两个关键字,实现方法的多返回值操作,只能说有一些尴尬了!
但静心一想,这两个关键字与异步的本质存在严重的分歧。因为异步不会阻塞主线程,接受请求后,让出线程忙自己的事情了,后续的任务由上下文进行关联,将结果返回给当初的请求者。
所以out与ref这两个关键字,在这个场景明显是不适用的。
不过我们此时可以通过元组来完美解决这个问题,在.NET Framework 4.0版本,元组与Task一起更新到版本之中,可见官方给出的技术方案是完全配套的。
元组犹如你的抽屉一般,什么乱七八糟的,都可以往里扔。接下来我们详细的学习下,元组系列知识,Tuple与ValueTuple。
Tuple:元组支持1到7个元组元素,如果有8个元素或者更多,需要使用Tuple的嵌套与Rest属性去实现。元组中的项,默认为item1到item7,这个key的名字为默认分配的,无法自定义改变!(这个也是元组与集合、字典不同的地方)
元组嵌套案例:
定义元组案例(典型分页方法,分页需要一个数据源,一个总数):
小伙伴们,目前我们已经掌握了Tuple元组的基本使用方式,是不是很方便啊!接下来继续学习下ValueTuple的使用方式,感受下性能版元组的魅力所在。
ValueTuple 是C# 7.0推出的,Tuple是类,引用类型的。而ValueTuple是枚举类型,为值类型。所以从资源消耗角度来说,ValueTuple更优秀一些。
另外ValueTuple允许是支持读写操作的,可以修改项的内容。ValueTuple同时还支持匿名写法,从编程角度,也优化了一波儿。
匿名方法写法:
转换成JSON格式案例:
老夫一口气终于写完了!觉觉去喽!
喜欢的小伙伴可以关注我,一起交流学习!我是IT鸟叔,一位喜欢写程序、钓鱼、喝茶、玩 游戏 的中年大叔!