我有一个UnitofWork
类,它实现了IUnitOfWork
。我试着用Autofac注册它:
var builder = new ContainerBuilder();
builder
.RegisterGeneric(typeof(UnitOfWork<Repository<>,>))
.As(typeof(IUnitOfWork))
.InstancePerDependency();
实现方式为:
public class UnitOfWork<T, O> : IUnitOfWork
where T : Repository<O>
where O : BaseEntity
{
}
public interface IUnitOfWork : IDisposable
{
void SaveChanges();
}
给出错误"Type expected"
但是这个工作在另一个项目上:
public class Repository<T> : GenericRepository<T>
where T : BaseEntity
{
public Repository(IDbContext context) : base(context) { }
}
public abstract class GenericRepository<T>
: IRepository<T>, IQueryable<T> where T : BaseEntity
{
}
builder
.RegisterGeneric(typeof(Repository<>))
.As(typeof(IRepository<>))
.InstancePerHttpRequest();
发布于 2013-03-06 00:14:31
您不能在typeof
,中部分打开类(例如,对于UnitOfWork<Repository<>,>
,您指定了T
,但没有指定O
) 在类中尝试使用:
var builder = new ContainerBuilder();
builder
.RegisterGeneric(typeof(UnitOfWork<,>))
.As(typeof(IUnitOfWork))
.InstancePerDependency();
where T : Repository<O>
泛型约束将处理第一个参数应该是Repository<>
,但它不能与 RegisterGeneric
一起使用,因为它需要一个通用接口,因此需要创建一个IUnitOfWork<T,O>
…
但是你的模型非常奇怪。为什么您的UnitOfWork
需要Repository<>
类型参数?
您可以在UnitOfWork<E>
构造函数中获取Repository<>
,而不是将其作为类型参数:
public class UnitOfWork<E> : IUnitOfWork<E> where E : BaseEntity
{
private readonly Repository<E> repository;
public UnitOfWork(Repository<E> repository)
{
this.repository = repository;
}
//.. other methods
}
Where IUnitOfWork<E>
public interface IUnitOfWork<E> : IDisposable where E : BaseEntity
{
void SaveChanges();
}
和Autofac注册:
var builder = new ContainerBuilder();
builder
.RegisterGeneric(typeof(Repository<>)).AsSelf();
builder
.RegisterGeneric(typeof(UnitOfWork<>))
.As(typeof(IUnitOfWork<>))
.InstancePerDependency();
var container = builder.Build();
// sample usage
var u = container.Resolve<IUnitOfWork<MyEntity>>();
https://stackoverflow.com/questions/15226536
复制相似问题