Squeak.ru - шаблоны программирования

Разница между режимами Dev и Prod в порядке инициализации модулей внедрения зависимостей

У меня есть приложение Play, и я использую библиотеки Play для DI с готовым Guice.

Некоторые из игровых модулей, которые я определяю, зависят друг от друга, и для того, чтобы они могли внедрять свои привязки в другой, я пытаюсь сохранить ссылку на инжектор Play в глобальном месте, т.е.

class MyApplicationLoader extends GuiceApplicationLoader() {
  override def builder(context: ApplicationLoader.Context): 
    GuiceApplicationBuilder = {
    val builder = super.builder(context)
    Global.Injector = builder.injector()
    builder
  }
}

Это хорошо работает, когда Play работает в режиме разработки, но в режиме производства вызов Global.Injector = builder.injector() вызывает циклическую зависимость, поскольку он вызывает модули и привязки, которые требуют инициализации Global.Injector, но на данный момент он еще не инициализирован.

Я понимаю, что это может быть связано с тем, что в режиме разработки активные синглтоны инициализируются первыми, тогда как в производственном режиме активные синглтоны и обычные синглтоны инициализируются вместе.

  1. Я правильно понимаю?
  2. Верен ли мой подход? Как решить проблему в производственном режиме?

Ответы:


1

Я пытаюсь сохранить ссылку на инжектор Play в глобальном месте.

В большинстве случаев в этом нет необходимости, и вы должны стараться избегать этого.

Похоже, что для решения вашей проблемы вам нужно использовать только аннотацию Provides, простой пример такой:

class MyModule extends AbstractModule {
  @Provides
  def complexConstructor(a: ObjA, b: ObjB): ComplexClass = ???
}

Этот подход не должен иметь никаких проблем.

08.11.2019
  • Ваш подход решил проблему, которая у меня была. Я все еще хотел ссылку на инжектор, потому что хотел избежать изменения большого количества кода. Поэтому я использовал ваш подход к методу @Provides и com.google.inject.Injector в качестве введенного параметра для этого метода. Разница, вероятно, в том, что я убедился, что никакие модули не ссылаются на инжектор, а только код извне модулей. 17.11.2019
  • Новые материалы

    Угловая структура архитектуры
    Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

    «Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
    Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

    Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
    В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

    Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
    React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

    Создайте API с помощью Python FastAPI
    Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

    Веселье с прокси-сервером JavaScript
    Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

    Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
    Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...