app/
di/
components/
modules
JakcApplication.kt
MainActivity.kt
core/
data/
local/
database/
models/
ProjectEntity.kt
PartEntity.kt
CounterEntity.kt
AppDatabase.kt
remote/
feature/
addproject/
data/
di/
page/
screen/
viewmodel/
home/
data/
di/
page/
screen
viewmodel/
< /code>
Как вы можете видеть, вот как я фиксируюсь чистой архитектурой, и я предполагаю, что специально погашайте по функции (однако, поправьте меня, если я ошибаюсь). < /p>
Теперь, в идеале, я бы хотел сохранить автономные функции. Тем не менее, я заметил, что типичный способ использования комнаты состоит в том, чтобы у вас было бы следующее: < /p>
@Database(
// ...
)
abstract class AppDatabase: RoomDatabase() {
abstract val projectDao: ProjectDao
companion object {
// ...
fun getDatabase(context: Context): AppDatabase {
// ...
}
}
}
< /code>
Теперь я также хочу использовать Dagger 2 в качестве инъекции зависимости. Я также знаю, что обычно, чтобы использовать комнату, она должна знать каждый DAO во время выполнения. Тем не менее, способ, которым он обычно настроен, создаст круговую зависимость: < /p>
ядро будет зависеть от каждой функции, чтобы получить вид DAO, и каждая функция будет зависеть от ядра, чтобы определить каждую функцию.feature/
addproject/
data/
local/
database/
dao/
ProjectDao.kt
PartDao.kt
CounterDao.kt
, а затем как -то введите DAO в AppDatabase или, альтернативно, зарегистрируйте их?
У меня есть следующая структура проекта: < /p> [code]app/ di/ components/ modules JakcApplication.kt MainActivity.kt core/ data/ local/ database/ models/ ProjectEntity.kt PartEntity.kt CounterEntity.kt AppDatabase.kt remote/ feature/ addproject/ data/ di/ page/ screen/ viewmodel/ home/ data/ di/ page/ screen viewmodel/ < /code> Как вы можете видеть, вот как я фиксируюсь чистой архитектурой, и я предполагаю, что специально погашайте по функции (однако, поправьте меня, если я ошибаюсь). < /p> Теперь, в идеале, я бы хотел сохранить автономные функции. Тем не менее, я заметил, что типичный способ использования комнаты состоит в том, чтобы у вас было бы следующее: < /p> @Database( // ... ) abstract class AppDatabase: RoomDatabase() { abstract val projectDao: ProjectDao
companion object { // ...
fun getDatabase(context: Context): AppDatabase { // ... } } } < /code> Теперь я также хочу использовать Dagger 2 в качестве инъекции зависимости. Я также знаю, что обычно, чтобы использовать комнату, она должна знать каждый DAO во время выполнения. Тем не менее, способ, которым он обычно настроен, создаст круговую зависимость: < /p> ядро будет зависеть от каждой функции, чтобы получить вид DAO, и каждая функция будет зависеть от ядра, чтобы определить каждую функцию.feature/ addproject/ data/ local/ database/ dao/ ProjectDao.kt PartDao.kt CounterDao.kt [/code] , а затем как -то введите DAO в AppDatabase или, альтернативно, зарегистрируйте их?