gpt4 book ai didi

task - Guice:提供程序中的注入(inject)器

转载 作者:行者123 更新时间:2023-12-01 13:03:05 27 4
gpt4 key购买 nike

我知道通常注入(inject)器应该在所有应用程序中只使用一次(在启动时)。但我有以下用例。我为 Executor 注入(inject)任务实现,然后在该任务中我有依赖项(可以说 FileHandler ),每次都必须实例化。我知道方法是注入(inject)提供者(可以说 FileHandlerProvider ),每次请求时都会返回新实例。问题是 FileHandler它自己有很多依赖项(可以说 ParserOutputPrinter ...)。现在那些也每次都需要新的实例(因为实现可能有一些状态,例如计数器,并且在下一个线程运行时重用相同的实例将是一个问题)。问题是在注入(inject)提供程序后,提供程序的相同实例被重用,所以新的 FileHandler始终使用相同的 Parser 创建和 OuputPrinter .解决方案可能是再次注入(inject) ParserProviderOutputPrinterProvider而不是 Parser 和 OuputPrinterFileHandlerProvider ,但那是不对的,它很快就会变得太复杂,因为有更多的依赖关系。我现在看到的唯一简单的解决方案可能是在 FileHandlerProvider 中使用 Injector ,这将返回新实例 FileHandler (以及新的依赖实例)。或者在这种情况下可能还有另一种更优雅的解决方案?

最佳答案

你应该绑定(bind)FileHandler及其依赖项都具有默认范围(即没有范围)。然后注入(inject)Provider<FileHandler>并使用它的get()每次你需要一个新的FileHandler实例。由于FileHandler没有作用域,每次get()被称为 FileHandler 的新实例需要创建......并且由于它的依赖关系也没有范围,因此每次也需要创建它们中的每一个的新实例。它应该按照您想要的方式工作。

我认为您(可能)在这里缺少的是您不需要自己编写任何这些提供程序...只需注入(inject) Provider<FileHandler> Guice 会为您做这一切。

编辑:这是我编写的一个小类,它演示了每次创建该类的实例时都会创建新的类的依赖关系。

public class Test {
public static void main(String[] args) {
Injector injector = Guice.createInjector();
injector.getInstance(Test.class);
}

@Inject public Test(Provider<FileHandler> fileHandlerProvider) {
FileHandler fileHandler1 = fileHandlerProvider.get();
FileHandler fileHandler2 = fileHandlerProvider.get();

System.out.println("fileHandler1 == fileHandler2? " +
(fileHandler1 == fileHandler2));
System.out.println("fileHandler1.parser == fileHandler2.parser? " +
(fileHandler1.parser == fileHandler2.parser));
System.out.println("fileHandler1.print == fileHandler2.printer? " +
(fileHandler1.printer == fileHandler2.printer));
}

private static class FileHandler {
private final Parser parser;
private final OutputPrinter printer;

@Inject private FileHandler(Parser parser, OutputPrinter printer) {
this.parser = parser;
this.printer = printer;
}
}

private static class Parser {
}

private static class OutputPrinter {
}
}

运行时,此代码打印:

文件处理程序1 == 文件处理程序2?错误的
fileHandler1.parser == fileHandler2.parser?错误的
fileHandler1.print == fileHandler2.printer?错误的

这表明不仅是一个新的 FileHandler每次创建的实例,新的 ParserOutputPrinter实例被创建并注入(inject)到 FileHandler每次也是如此。

关于task - Guice:提供程序中的注入(inject)器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4768970/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com