c# – 列出不同的值类型

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

现在我想创造

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

并向其添加元素:

@H_502_3@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属性处理列表项,那么您可以在这里提取一些基类/接口:

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

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

@H_502_3@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>存储实例并处理它们:

@H_502_3@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#相关文章