Symfony2中的依赖注入最佳实践

gen*_*sst 3 dependency-injection symfony

在Symfony2(本例中为2.8)中,将服务注入其他服务时,最佳做法是什么?

/**
 * Checker constructor.
 * @param EntityManager $em
 * @param EventDispatcherInterface $dispatcher
 */
public function __construct(EntityManager $em, EventDispatcherInterface $dispatcher)
{
    $this->repoUser = $em->getRepository(User::class);
    $this->repoPurchase = $em->getRepository(Purchase::class);
    $this->repoTicket = $em->getRepository(Ticket::class);
    $this->dispatcher = $dispatcher;
}
Run Code Online (Sandbox Code Playgroud)

要么

/**
 * Checker constructor.
 * @param UserRepository $ur
 * @param PurchaseRepository $pr
 * @param TicketRepository $tr
 * @param EventDispatcherInterface $dispatcher
 */
public function __construct(UserRepository $ur, PurchaseRepository $pr, TicketRepository $tr, EventDispatcherInterface $dispatcher)
{
    $this->repoUser = $ur;
    $this->repoPurchase = $pr;
    $this->repoTicket = $tr;
    $this->dispatcher = $dispatcher;
}
Run Code Online (Sandbox Code Playgroud)

或明确使用setter并在其中单独设置参数services.yml

我想知道等式的性能部分是什么.

Mak*_*hev 7

两种情况都有利弊.

  • 性能方面,两个选项都是相同的,因为只有在请求服务实例时才会获得存储库实例.无论你手动完成,还是由DI自动完成.在这里,

    容器是懒惰的:它不会实例化服务,直到(并且除非)你要求它.

  • 如果您要使用单元测试来覆盖您的服务- 那么选项2肯定会更好,因为您不需要在测试开始时模拟$ em-> getRepository()调用.

  • 个人制定者的好处- 也与单元测试有关.例如,对于一个测试用例,您只需要一个依赖项,另一个测试用例 - 另一个依赖项.因此,您可以在test中使用setter来设置模拟,而不需要将所有模拟传递给构造函数.

  • 仔细查看发布的代码.一旦构建了服务,就会从实体管理器中提取存储库.没有性能差异.关于单元测试和个人设置的第三点是非常紧张.要么类需要依赖,要么不需要它.如果一个类在某些时候只需要一些依赖,那么它应该可能被重构. (3认同)