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

    }

  • 相关阅读:
    java中abstract详解
    java synchronized详解
    java单列设计模式 小记
    java中static 和 final 的一些使用规则
    Java cookie和session介绍与区别
    java中string stringbuilder stringbuffer 的区别
    java中final的作用
    报错信息:ORA-00979:不是GROUP BY表达式
    解决异常信息 Caused by: java.lang.IllegalArgumentException: invalid comparison: java.lang.String and java.util.Date
    spring boot 集成 mybatis 单元测试Dao层 控制台报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found):
  • 原文地址:https://www.cnblogs.com/liangss/p/5143396.html
Copyright © 2011-2022 走看看