C#中Tuple的使用
来源:互联网 发布:淘宝开放平台自己开发 编辑:程序博客网 时间:2024/06/16 11:05
鉴于MSDN上面的机器翻译实在太烂,还是自己翻译吧,虽然麻烦了点(-_-)。
定义:元组是具有 特定数量和序列 的元素 的数据结构 (注意断句哈!)
元组通常有四种使用方式︰
一、表示一组数据
例如,一个元组可以表示一条数据库记录,并且每一个分量对应表示这条记录的每个字段便于对数据集进行访问和操作,例如下面这个例子(数据集市每个学生和他的分数,最后求出所有成绩的学生的平均分数):
二、便于对数据集进行访问和操作
例如下面这个例子(数据集市每个学生和他的分数,最后求出所有成绩的学生的平均分数):
using System;public class Example{ public static void Main() { Tuple<string, Nullable<int>>[] scores = { new Tuple<string, Nullable<int>>("Jack", 78), new Tuple<string, Nullable<int>>("Abbey", 92), new Tuple<string, Nullable<int>>("Dave", 88), new Tuple<string, Nullable<int>>("Sam", 91), new Tuple<string, Nullable<int>>("Ed", null), new Tuple<string, Nullable<int>>("Penelope", 82), new Tuple<string, Nullable<int>>("Linda", 99), new Tuple<string, Nullable<int>>("Judith", 84) }; int number; double mean = ComputeMean(scores, out number); Console.WriteLine("Average test score: {0:N2} (n={1})", mean, number); } private static double ComputeMean(Tuple<string, Nullable<int>>[] scores, out int n) { n = 0; int sum = 0; foreach (var score in scores) { if (score.Item2.HasValue) { n += 1; sum += score.Item2.Value; } } if (n > 0) return sum / (double) n; else return 0; }}// The example displays the following output:// Average test score: 88 (n=7)
三、一个方法有多个返回值无需使用out参数(事实上我就是用的这种方式)
贴一段我的代码
public Tuple<int, string> ManEntryPN(DateTime recTime, double netLossRate, double electricityOnline, double electricitySell) { //检验查询 Tuple<int, string> tuple = null; string testProc = "queryManagePageData"; SqlParameter[] testParas = new SqlParameter[] { new SqlParameter("@recTime",recTime), new SqlParameter("@netLossRate",netLossRate), new SqlParameter("@electricityOnline",electricityOnline), new SqlParameter("@electricitySell",electricitySell), new SqlParameter("@indexName","TestManEntryPN") }; DataTable dt = new DataTable(); dt = sqlhelper.ExecuteQuery(testProc, testParas, CommandType.StoredProcedure); if (dt.Rows.Count > 0) { //如果该日期数据已经录入 return tuple = new Tuple<int, string>(1, recTime + "数据已经录入"); } //数据录入 string insertProc = "queryManagePageData"; SqlParameter[] insertParas = new SqlParameter[] { new SqlParameter("@recTime",recTime), new SqlParameter("@netLossRate",netLossRate), new SqlParameter("@electricityOnline",electricityOnline), new SqlParameter("@electricitySell",electricitySell), new SqlParameter("@indexName","ManEntryPN") }; int res = sqlhelper.ExecuteNonQuery(insertProc, insertParas, CommandType.StoredProcedure); if (res > 0) { //如果录入成功 return tuple = new Tuple<int, string>(0, "Sucess"); } return tuple = new Tuple<int, string>(1, "插入失败"); }
四、将多个值传给单个参数的方法
例如,Thread.Start(Object) 方法只有一个参数,即你可以传一个值给该线程的启动方法。 如果你提供Tuple<T1, T2, T3> 对象作为方法参数,则你可以给该线程的启动方法传3个值。
0 0
- C#中Tuple的使用
- C#中Tuple的使用
- C#中Action、Func、Tuple的使用
- C++11中std::tuple的使用
- C# Tuple的用法
- C++中使用tuple
- C# Tuple<T1,T2....T>元组的使用
- Tuple的使用场景
- tuple的使用
- Visual Studio2017中编写ASP.NET程序时使用C# 7.0元组Tuple新特性的一点注意事项
- C#元祖Tuple的事例
- Scala中Tuple(元组)的使用
- C# 使用Tuple传递多个参数
- 关于tuple的创建中
- Postgres中tuple的组装
- list 和tuple的使用
- C#的元组Tuple类型
- python中tuple(元组)使用总结
- Ignoring InnerClasses attribute for an anonymous inner class问题解决
- cookie-子cookie
- iOS博文收藏
- 线程内如何更新UI的另类实现
- Mike and Shortcuts
- C#中Tuple的使用
- 3、控制语句
- 矩阵键盘扫描实验报告
- PCON寄存器实验报告
- 51Nod——完美字符串
- 简单require.js
- 企业电脑升级kvm桌面虚拟化软件解决方案
- Laravel入门教程: 实现简单的AJAX的CRUD页面
- 使用 let 解决for 循环闭包 i变量问题