zoukankan      html  css  js  c++  java
  • 浅谈Tuple之C#4.0新特性

    一、4.0新特性中的Tuple

    大家可以回顾一下c#4.0中增加的一个新特性,元组Tuple,它是一种固定成员的泛型集合:


    下面先看看官方的一个使用例子:

    创建一个包含7个元素的Tuple数组

    // Create a 7-tuple.

    var population = new Tuple<string, int, int, int, int, int, int>( "New York", 7891957, 7781984, 7894862, 7071639, 7322564, 8008278);// Display the first and last elements.

    Console.WriteLine("Population of {0} in 2000: {1:N0}",population.Item1, population.Item7);

    用法非常简单方便,普通的方式我们可能需要这样:

    public class A{ 

     public int ID{get;set;} 

     public string Name{get;set;}

    }

    A a=new A(){ID=1001,Name='CodeL'};

    Console.WriteLine(a.Name);


    而使用Tuple我们只需要这样:

    Tuple<int,string> a=new Tuple<int,string>(1001,'CodeL');

    Console.WriteLine(a.Item2);//Item1 代表第一个,Item2代表第二个


    这样我们就可以不用为了 一些简单的结构或对象而去新建一个类了。
    注意的是tuple最多支持8个成员,注意第8个成员很特殊,如果有8个成员,第8个必须是嵌套的tuple类型。

    列如:Tuple<string, int, int, int, int, int, int, Tuple<int, int, int>>  红色部分是第8个。

    第8个元素使用方法:对象.Rest.Item1,对象.Rest.Item2

     

    二、实际场景举例

    我们使用Tuple来完成一次简单数据集的传递工作。

    将Tuple作为返回值

    public List<Tuple<int,string,DateTime>> GetUsers(){ 

      string sql="select ID,Name,CreateTime from Tbl_Users";

    using (SqlDataReader r = SqlHelper.ExecuteReader(Connections.AdminDBConString, CommandType.Text, sql))   

     {             

            List<Tuple<int,string,DateTime>> list = new List<Tuple<int,string,DateTime>>(); 

                  while (r.Read()) 

                  { 

                      Tuple<int,string,DateTime> t = new Tuple<int,string,DateTime>(Convert.ToInt32(r[0]),r[1].ToString(),Convert.ToDatetime(r[2])); 

                      list.Add(t);

                    } 

                  return list; 

              }

    }

    使用也非常方便:

    List<Tuple<int,string,datetime>> list=GetUsers();

    foreach(Tuple<int,string,datetime> t in list)

     Console.write(t.Item1);//ID 

     Console.write(t.Item2);//Name

       Console.write(t.Item3);//CreateTime

    }

  • 相关阅读:
    ExecuteNonQuery()返回值
    GridView导入至EXCEL (报错处理:只能在执行 Render() 的过程中调用 RegisterForEventValidation)
    mysql 远程登录
    四舍六入 银行家算法
    linux-grep-tail-find
    spring 事务注解
    aop execution 表达式解析
    事务有效条件
    oracle 日期取 月 日
    spring cloud 定时任务
  • 原文地址:https://www.cnblogs.com/liangss/p/5143396.html
Copyright © 2011-2022 走看看