如何解决C#中泛型类型约束的局限性?
发布时间:2020-12-15 04:30:58 所属栏目:百科 来源:网络整理
导读:好的,我正在寻找一些输入,我很确定.NET 3.5目前不支持这个,但是这里有. 我想要一个传递给我的类的泛型类型有一个像这样的构造函数: new(IDictionarystring,object) 所以班级看起来像这样 public MyClassT where T : new(IDictionarystring,object){ T Creat
好的,我正在寻找一些输入,我很确定.NET 3.5目前不支持这个,但是这里有.
我想要一个传递给我的类的泛型类型有一个像这样的构造函数: new(IDictionary<string,object>) 所以班级看起来像这样 public MyClass<T> where T : new(IDictionary<string,object>) { T CreateObject(IDictionary<string,object> values) { return new T(values); } } 但是编译器不支持这个,它并不真正知道我在问什么. 有些人可能会问,你为什么要这样做?好吧,我正在研究ORM的宠物项目,所以我从数据库中获取值,然后创建对象并加载值. 我认为允许对象只使用我给它的值创建自己会更清晰.据我所知,我有两个选择: 1)使用反射(我试图避免)来获取PropertyInfo []数组,然后使用它来加载值. 2)要求T支持这样的接口: 公共接口ILoadValues 然后这样做 public MyClass<T> where T:new(),ILoadValues { T CreateObject(IDictionary<string,object> values) { T obj = new T(); obj.LoadValues(values); return obj; } } 我猜这个界面的问题是哲学的,我真的不想公开一种公共方法供人们加载值.使用构造函数的想法是,如果我有一个像这样的对象 namespace DataSource.Data { public class User { protected internal User(IDictionary<string,object> values) { //Initialize } } } 只要MyClass< T>在同一个程序集中,构造函数可用.我个人认为我认为Type约束应该问(我有权访问这个构造函数吗?我做的很棒!) 无论如何,欢迎任何输入. 解决方法
如果您可以为要作为类型参数传递给MyClass的所有T对象创建公共基类,则可以执行以下操作:
internal interface ILoadValues { void LoadValues<TKey,TValue>(IDictionary<TKey,TValue> values); } public class Base : ILoadValues { void ILoadValues.LoadValues<TKey,TValue> values) { // Load values. } } public class MyClass<T> where T : Base,new() { public T CreateObject(IDictionary<string,object> values) { ILoadValues obj = new T(); obj.LoadValues(values); return (T)obj; } } 如果你不能拥有共同的基类,我认为你应该选择itowlson提出的解决方案. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- XML-世界上最难学的语言,我的XML创新之路(2)
- c# – mousedown上的自动滚动问题
- ruby-on-rails – 如何按列对Rails ActiveRecord结果进行分
- 将AJAX放在Joomla模块中
- ArcGis for flex 中QueryTask查询结果限制(1000)问题
- 常用正则表达式
- ruby-on-rails – Rails 3.2.1中ActionMailer中未定义的方法
- Flex Viewer 开发教程(6)Widget与共享数据
- Ajax XMLHTTP对象参考 ( 2008-06-03 15:34:19| 分类: jsp+
- sqlite中int 类型怎么转换成小数点类型(double或decimal)