我最近一直在研究一个通用工厂,该工厂绕过了关于带参数的构造函数的'where'约束,并且由于错误,我遇到了一些我不太了解并且想知道是否有人能够在它上面发光。
有问题的代码行是:
ITestInterface myObj = new GenericFactory<ITestInterface>(
() => (new TestClass("username", "password"))
).CreateObject() as ITestInterface;
ITestInterface myNewObj = new GenericFactory<ITestInterface>(
(string x, string y) => (new TestClass(x, y))
).CreateObject("username ", " password") as ITestInterface;
这两行都做同样的事情,但我预计第一行会失败。
工厂中的代码如下:
public GenericFactory (Func<T> getNewT)
{
_getNewObject = getNewT;
}
public GenericFactory(Func<string, string, T> getNewT)
{
_getNewObjectTwoParams = getNewT;
}
public T CreateObject ()
{
if (_getNewObject == null)
{
return default(T);
}
else
{
return _getNewObject();
}
}
public T CreateObject (string username, string password)
{
if (_getNewObjectTwoParams == null)
{
return default(T);
}
else
{
return _getNewObjectTwoParams(username, password);
}
}
TestClass具有以下构造函数:
public TestClass (string name, string password)
{
_name = name;
_password = password;
}
如果有人能够了解为什么第一次打电话到工厂的原因我会非常感激。
感谢。
答案 0 :(得分:2)
这看起来似乎有很多开销,相当于:
ITestInterface test = new TestClass("username", "password");
但是,它正常工作的原因是因为你正在使用第一个构造函数覆盖:
public GenericFactory (Func<T> getNewT)
您可以传入任何返回Func<T>
实例的T
。你可以在这个功能中做更多的事情:
ITestInterface myObj = new GenericFactory<ITestInterface>(
() => {
var username = GetMyUserName();
var password = GetMyPassword();
return new TestClass(username, password)
}).CreateObject() as ITestInterface;