c# – 列出不同的值类型
发布时间:2020-12-15 08:08:11 所属栏目:百科 来源:网络整理
导读:C#. 我上课了: public class SQLValueT { public string nam { get; set; } public string typ { get; set; } public T val { get; set; } } 现在我想创造 ListSQLValue lst = ListSQLValue(); 并向其添加元素: lst.Add(new ListSQLValue(nam = "PlayerNam
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>, 但是,假设您要根据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. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |