我有IServiceHandler和ISalesHandler,都是从Ihandler继承的
IHandler.cs
public interface IHandler
{
Task AddAsync(IEnumerable<IDictionary<string, object>> toAdd, int dataFileId);
Task AddAuditAsync(IEnumerable<IDictionary<string, object>> toAdd, int dataFileId);
}IServiceHandler.cs
public interface IServiceHandler : IHandler
{
Task<IEnumerable<ACService>> GetAsync();
Task<IEnumerable<ACServiceAudit>> GetAuditAsync();
}ISalesHandler.cs
public interface ISalesHandler : IHandler
{
Task<IEnumerable<ACSale>> GetAsync();
Task<IEnumerable<ACSaleAudit>> GetAuditAsync();
}然后,我有一个返回销售或服务的方法,但问题是我将它作为IHandler返回
private IHandler CreateHandler(FileType type)
{
switch (type)
{
case FileType.Sales:
return _container.GetExportedValue<ISalesHandler>("Sales");
case FileType.Service:
return _container.GetExportedValue<IServiceHandler>("Service");
case FileType.None:
return null;
}
return null;
}这使我只能访问IHandler中的方法,而不是IServiceHandler或ISalesHandler中的方法。
如何构造接口,以便能够访问所有方法?我更愿意保留CreateHandler方法。
发布于 2016-04-12 08:59:41
实际上,您正在返回一个IHandler,因此在那里定义的方法无需强制转换即可访问。
我认为可以通过使用泛型来规避这一切,因为派生处理程序中似乎有一种模式。
这对你有好处吗?
IHandler.cs
public interface IHandler // I usually split the generic and non-generic methods
{
Task AddAsync(IEnumerable<IDictionary<string, object>> toAdd, int dataFileId);
Task AddAuditAsync(IEnumerable<IDictionary<string, object>> toAdd, int dataFileId);
}
public interface IHandler<TService, TServiceAudit> : IHandler
{
Task<IEnumerable<TService>> GetAsync();
Task<IEnumerable<TServiceAudit>> GetAuditAsync();
}IServiceHandler.cs
public interface IServiceHandler : IHandler<ACService, ACServiceAudit>
{ }ISalesHandler.cs
public interface ISalesHandler : IHandler<ACSale, ACSaleAudit>
{ }发布于 2016-04-12 09:00:57
如何使用通用接口呢?
public interface IServiceHandler<TSale, TAudit> : IHandler
{
Task<IEnumerable<TSale>> GetSaleAsync();
Task<IEnumerable<TAudit>> GetAuditAsync();
}我只是将您的GetAsync()重命名为GetSaleAsync(),以便更加明确,但这是您希望的。因此,您的Factory可以具有以下签名:
private IServiceHandler<TSale, TAudit>CreateHandler(FileType type)https://stackoverflow.com/questions/36568236
复制相似问题