龙空技术网

编程小知识,在C#中如何让一个方法返回多个值

跟鸟叔学编程 1272

前言:

如今各位老铁们对“java多线程返回结果汇总”大概比较关心,朋友们都需要知道一些“java多线程返回结果汇总”的相关资讯。那么小编也在网摘上搜集了一些关于“java多线程返回结果汇总””的相关内容,希望小伙伴们能喜欢,你们快快来了解一下吧!

前言:

在日常的程序编写中,我们可能会遇到这样的需求!就是让一个方法,返回多个值,或者多种类型的值!

这类问题其实比较好解决,方案有很多种!本次讲解下,在C#语言中,此类问题的解决方案!

Ref与Out关键字:

如果长期从事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关键字使用错误案例:

Tuple、ValueTuple(元组类、值元组):

C#进入到异步时代,异步多线程编程模型,在如今的.NET技术体系中,可以说遍地开花般的存在。

这种异步编程模型,也让.NET CORE有了更优秀的性能,无论是吞吐量,还是程序执行性能,都有了质的飞跃。

回顾下异步方法定义三部曲:

1:async后缀,见名知意。

2:返回类型只能为void、Task、Task<T>,推荐2、3。

3:参数不能用out、ref关键字修饰。

此时的“小麻烦”来了,异步虽好,但是无法使用上述讲到的两个关键字,实现方法的多返回值操作,只能说有一些尴尬了!

但静心一想,这两个关键字与异步的本质存在严重的分歧。因为异步不会阻塞主线程,接受请求后,让出线程忙自己的事情了,后续的任务由上下文进行关联,将结果返回给当初的请求者。

所以out与ref这两个关键字,在这个场景明显是不适用的。

不过我们此时可以通过元组来完美解决这个问题,在.NET Framework 4.0版本,元组与Task一起更新到版本之中,可见官方给出的技术方案是完全配套的。

元组犹如你的抽屉一般,什么乱七八糟的,都可以往里扔。接下来我们详细的学习下,元组系列知识,Tuple与ValueTuple。

Tuple:元组支持1到7个元组元素,如果有8个元素或者更多,需要使用Tuple的嵌套与Rest属性去实现。元组中的项,默认为item1到item7,这个key的名字为默认分配的,无法自定义改变!(这个也是元组与集合、字典不同的地方)

//实例化方式创建元组            var t1 = new Tuple<int, int, int, int, int, int, int>(1,2,3,4,5,6,7);            //通过静态方法创建元组            var t2 = Tuple.Create<string, int, bool, char[]>                ("james", 2, false,new char[] {'a','b','c'});            //访问t1元组内容            Console.WriteLine($"{t1.Item1},{t1.Item7}");            //访问t2元组内容            Console.WriteLine($"{t2.Item1},{t2.Item2},{t2.Item3}");            char[] array = t2.Item4;            foreach (var c in array)             {                Console.WriteLine(c);            }

元组嵌套案例:

//实例化方式创建元组            var t1 = new Tuple<int, int, int, int, int, int, int,Tuple<int,string>>(1,2,3,4,5,6,7,new Tuple<int,string>(1,"abcdefg"));            //元组嵌套的元组通过Rest去访问,内置元素也是item1-item7            Console.WriteLine($"{t1.Item1},{t1.Rest.Item1},{t1.Rest.Item2}");

定义元组案例(典型分页方法,分页需要一个数据源,一个总数):

public static Tuple<List<Student>,int> GetTuple()         {            int count = 10086;            List<Student> list = new List<Student>()             {                new Student(){Name="周三",Age=20},                new Student(){Name="里三",Age=21},                new Student(){Name="王三",Age=22}            };            return new Tuple<List<Student>, int>(list,count);        }

小伙伴们,目前我们已经掌握了Tuple元组的基本使用方式,是不是很方便啊!接下来继续学习下ValueTuple的使用方式,感受下性能版元组的魅力所在。

ValueTuple是C# 7.0推出的,Tuple是类,引用类型的。而ValueTuple是枚举类型,为值类型。所以从资源消耗角度来说,ValueTuple更优秀一些。

另外ValueTuple允许是支持读写操作的,可以修改项的内容。ValueTuple同时还支持匿名写法,从编程角度,也优化了一波儿。

匿名方法写法:

static (string, int, bool) GetStudentInfo()        {            return ("hello world ", 28, true);        }

转换成JSON格式案例:

var t1 = GetStudentInfo();            var t2 = GetTuple();            var t3 = Tuple.Create<int, int, int>(1,2,3);            var t4 = ValueTuple.Create<int, int, int, int, int, int, Tuple<string, string>>(1,2,3,4,5,6,new Tuple<string, string>("aaa","bbb"));            Console.WriteLine(JsonConvert.SerializeObject(t1));            Console.WriteLine(JsonConvert.SerializeObject(t2));            Console.WriteLine(JsonConvert.SerializeObject(t3));            Console.WriteLine(JsonConvert.SerializeObject(t4));
总结一下:

老夫一口气终于写完了!觉觉去喽!

喜欢的小伙伴可以关注我,一起交流学习!我是IT鸟叔,一位喜欢写程序、钓鱼、喝茶、玩游戏的中年大叔!

标签: #java多线程返回结果汇总 #线程返回结果