可以注册一个具有预期从创建点传递的参数的类吗?
我知道可以这样做:
GlobalContainer.RegisterType<TUserProcessor>.Implements<IUserUpgrader>.
AsTransient.Delegateto(
function: TUserProcessor
begin
Result := TUserProcessor.Create(GetCurrentUser);
end
);
但是参数被绑定到容器被注册的执行上下文,而不是对象得到实例化的位置.
这样的事情可能就是这样吗?
GlobalContainer.Resolve<IMathService>([FCurrentUser]);
我知道一些peoble的拥护者拥有非常简单的构造函数,但有时候构造函数参数看起来很清楚:
>构造的对象需要使用object参数,因此必须满足引用.该参数还使该约束在类中更加明显.
>您可以在方法或属性中分配引用,并在每个其他方法中引发异常,如果您在没有先完成赋值的情况下尝试使用该对象.我不喜欢编写这种类型的代码,这只是浪费时间,只需使用构造函数参数并检查那里.代码越少,IMO越好.
>此外,传递它的对象是使用容器(例如Transaction对象)构造新对象的对象的本地对象,并且具有某种状态(它不是我可以通过容器获得的新对象).
解决方法
我在Unity中添加了解析器覆盖.
所以你可以写:
program Demo;
{$APPTYPE CONSOLE}
uses
Classes,Spring.Container,Spring.Container.Resolvers;
type
IUserUpgrader = interface
['{ADC36759-6E40-417D-B6F7-5DCADF8B9C07}']
end;
TUser = class(TObject);
TUserProcessor = class(TInterfacedobject,IUserUpgrader)
public
constructor Create(AUser: TUser);
end;
constructor TUserProcessor.Create(AUser: TUser);
begin
Writeln('called constructor with passed user');
end;
begin
GlobalContainer.RegisterType<TUserProcessor>.Implements<IUserUpgrader>;
GlobalContainer.Build;
GlobalContainer.Resolve<IUserUpgrader>(
TOrderedParametersOverride.Create([TUser.Create]));
GlobalContainer.Resolve<IUserUpgrader>(
TParameterOverride.Create('AUser',TUser.Create));
Readln;
end.