1

我正在尝试使用在泛型方法的参数列表ValueTuple中简洁地输入N类型列表,然后再迭代该类型列表。

但是,我在迭代类型时遇到了问题,因为初始Tuplenull成员,所以调用.GetType()会给我一个 NullReferenceException。

我意识到我可以使用 Type 对象的实际列表来做我需要的事情,但我更喜欢创建元组时允许的非常简洁的语法......当然因为这样的事情让我很感兴趣 :)

public static void IterateTupleMemberTypes<T>() where T : ITuple, new()
{
   var tuple = new T();
   for (var i = 0; i < tuple.Length; ++i)
   {
      //First call to GetType() succeeds, first element is an int.
      //Second call to GetType() fails (null ref ex), second element is a string.
      Console.WriteLine($"Item{i} Type: {tuple[i].GetType()}");
   }
}

用法

public class CustomClass
{
   public int ID { get; set; }
}

IterateTupleMemberTypes<(int, string, CustomClass)>();
4

1 回答 1

0

我认为您正在混合数据和元数据。第一次调用成功,因为 int 是值类型,并且 default(int) 将值分配给 0,所以它可以工作。这不适用于引用类型,因为它们最初分配给 null。

我相信这里的正确方法是反射 - 并迭代类型的属性,而无需创建实例(因此 new() 限制是多余的)。

public static void IterateTupleMemberTypes<T>() where T : ITuple
{
    var tupleGenericArguments = typeof(T).GetGenericArguments();
    for (var i = 0; i < tupleGenericArguments.Length; ++i)
    {
        Console.WriteLine($"Item{i} Type: {tupleGenericArguments[i].Name}");
    }
}
于 2018-01-04T01:39:04.187 回答