在一间非通用类中声明这两个方法,它们共享相同的签名:Func键委托声明的方法
private TypeResolverResult<T> TryRetrieveFromReusable<T>(TypeResolverConfiguration<T> typeResolverConfiguration) where T : class
{
return null;
}
private TypeResolverResult<T> BuildNew<T>(TypeResolverConfiguration<T> typeResolverConfiguration) where T : class
{
return null;
}
如何创建一个表示这些方法签名的委托?
我似乎无法得到它,我想:
private Func<TypeResolverConfiguration<T>, TypeResolverResult<T>> _typeResolveFunc;
但明显这不起作用,因为类是不通用的,我不能改变的。
感谢
UPDATE
这是多了还是少了什么,我需要:
public class Manager : ATypeResolver, IManager
{
private neeedDelegate;
public Manager(RuntimeConfiguration runtimeConfiguration, IList<RepositoryContainer> repositories)
{
if (runtimeConfiguration.WhatEver)
{
neeedDelegate = TryRetrieveFromReusable;
}
else
{
neeedDelegate = BuildNew;
}
}
public override TypeResolverResult<T> Resolve<T>() where T : class
{
//Want to avoid doing this:
if (runtimeConfiguration.WhatEver)
{
TryRetrieveFromReusable(new TypeResolverConfiguration<T>());
}
else
{
BuildNew(new TypeResolverConfiguration<T>());
}
//and have just this
neeedDelegate<T>(new TypeResolverConfiguration<T>());
}
private TypeResolverResult<T> TryRetrieveFromReusable<T>(TypeResolverConfiguration<T> typeResolverConfiguration) where T : class
{
return null;
}
private TypeResolverResult<T> BuildNew<T>(TypeResolverConfiguration<T> typeResolverConfiguration) where T : class
{
return null;
}
}
在什么情况下你想使用它?如果什么都不是通用的,那么很难拥有泛型类型参数。即使类型不是因为调用者定义了类型,方法也可以是通用的。但是,除非包含类型是通用的,否则字段和属性不能是通用的。 – cadrell0
@ cadrell0这些方法是通用的,但类不是通用的,它们有一个已定义的约束:class – Marco
@ cadrell0是的,你是对的,回到开头。 – Marco