如何解决C#中泛型类型约束的局限性?

前端之家收集整理的这篇文章主要介绍了如何解决C#中泛型类型约束的局限性?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
好的,我正在寻找一些输入,我很确定.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
{
void LoadValues(IDictionary values);
}

然后这样做

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提出的解决方案.

猜你在找的C#相关文章