c# – 列出不同的值类型

前端之家收集整理的这篇文章主要介绍了c# – 列出不同的值类型前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
C#.
我上课了:
public class sqlValue<T> 
{ 
    public string nam { get; set; } 
    public string typ { get; set; } 
    public T val      { get; set; } 
}

现在我想创造

List<sqlValue> lst = List<sqlValue>();

并向其添加元素:

lst.Add(new List<sqlValue>(nam = "PlayerName",typ = "string",val = "Bot1"));
lst.Add(new List<sqlValue>(nam = "Ally",typ = "bool",val = true));
lst.Add(new List<sqlValue>(nam = "Levl",typ = "int",val = 2));

所以我想要一个包含不同类型值val的类列表.这是真的吗?

解决方法

你不能.

需要一些基本类型.显然,你总是可以使用List< object>,
如果你只想存储sqlValue< T>实例.

但是,假设您要根据nam和typ属性处理列表项,那么您可以在这里提取一些基类/接口:

public interface IsqlValue
{
    public string nam { get; set; } 
    public string typ { get; set; } 
    public object val { get; set; }
}

sqlValue< T>中实现它这条路:

public class sqlValue<T> : IsqlValue
{ 
    public string nam { get; set; } 
    public string typ { get; set; } 

    public T val { get; set; } 

    object IsqlValue.val 
    {  
        get { return this.val; }
        set { this.val = (T)value; }
    }
}

并使用List< IsqlValue>存储实例并处理它们:

var sqlValues = new List<IsqlValue>
{
    new sqlValue<string> { nam="PlayerName",typ="string",val="Bot1" }
    new sqlValue<bool> { nam="Ally",typ="bool",val=true }
    new sqlValue<int> { nam="Levl",typ="int",val=2 }
};

foreach (var value in sqlValues)
{
    Console.WriteLine($"nam = {value.name},typ = {value.typ},val = {value.val}");
}

也就是说,在某些批处理的情况下,将使用IsqlValue.但是如果您知道特定IsqlValue的T,则可以将其强制转换为sqlValue< T>并使用T val而不是object val.

猜你在找的C#相关文章