- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Dagger2 进行 DI 项目。我在 MVP 架构中注入(inject) Presenter。出于某种原因,当我构建应用程序时,它因错误而崩溃:“lateinit 属性演示器尚未初始化”。我知道这意味着没有进行注入(inject),但我不明白为什么。这是我的代码:
应用类
class FlowerApp : Application() {
override fun onCreate() {
super.onCreate()
initAppComponent()
}
private fun initAppComponent() {
appComponent = DaggerAppComponent
.builder()
.appModule(AppModule(this))
.build()
}
companion object {
lateinit var appComponent: AppComponent
}
}
家庭模块
@Module
class HomeModule(var homeFragment: HomeContract.View) {
@Provides
fun providePresenter(homeInteractor: HomeInteractor): HomePresenter {
return HomePresenter(homeFragment, homeInteractor)
}
@Provides
fun provideInteractor(): HomeInteractor {
return HomeInteractor()
}
}
应用组件
@Component(
modules = [
(AppModule::class),
(NetworkModule::class),
(HomeModule::class)
]
)
interface AppComponent {
fun inject(application: FlowerApp)
fun inject(homeFragment: HomeContract.View)
}
主页 fragment
class HomeFragment : Fragment(), HomeContract.View {
@Inject
lateinit var presenter: HomePresenter
private lateinit var flowerAdapter: FlowerAdapter
private var startingPage = 1
private var recyclerStartPos = 0
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
return inflater.inflate(R.layout.fragment_home, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
setAdapter()
presenter.getFlowers(startingPage)
setListeners()
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
FlowerApp.appComponent.inject(this)
}
如果需要有关代码的任何其他信息,请询问...
编辑:logcat 错误:
2020-06-06 22:12:37.513 13401-13401/? E/AndroidRuntime:致命异常:主要 进程:element.list.flowersmvp,PID:13401 kotlin.UninitializedPropertyAccessException: lateinit property presenter 尚未初始化 在 element.list.flowersmvp.home.HomeFragment.onViewCreated(HomeFragment.kt:37) 在 androidx.fragment.app.FragmentManagerImpl.moveToState(FragmentManagerImpl.java:892) 在 androidx.fragment.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManagerImpl.java:1238) 在 androidx.fragment.app.FragmentManagerImpl.moveToState(FragmentManagerImpl.java:1303) 在 androidx.fragment.app.BackStackRecord.executeOps(BackStackRecord.java:439) 在 androidx.fragment.app.FragmentManagerImpl.executeOps(FragmentManagerImpl.java:2079) 在 androidx.fragment.app.FragmentManagerImpl.executeOpsTogether(FragmentManagerImpl.java:1869) 在 androidx.fragment.app.FragmentManagerImpl.removeRedundantOperationsAndExecute(FragmentManagerImpl.java:1824) 在 androidx.fragment.app.FragmentManagerImpl.execPendingActions(FragmentManagerImpl.java:1727) 在 androidx.fragment.app.FragmentManagerImpl.dispatchStateChange(FragmentManagerImpl.java:2663) 在 androidx.fragment.app.FragmentManagerImpl.dispatchActivityCreated(FragmentManagerImpl.java:2613) 在 androidx.fragment.app.FragmentController.dispatchActivityCreated(FragmentController.java:246) 在 androidx.fragment.app.FragmentActivity.onStart(FragmentActivity.java:542) 在 androidx.appcompat.app.AppCompatActivity.onStart(AppCompatActivity.java:201) 在 android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1392) 在 android.app.Activity.performStart(Activity.java:7252) 在 android.app.ActivityThread.handleStartActivity(ActivityThread.java:2970) 在 android.app.servertransaction.TransactionExecutor.performLifecycleSequence (TransactionExecutor.java:180) 在 android.app.servertransaction.TransactionExecutor.cycleToPath(TransactionExecutor.java:165) 在 android.app.servertransaction.TransactionExecutor.executeLifecycleState(TransactionExecutor.java:142) 在 android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:70) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1831) 在 android.os.Handler.dispatchMessage(Handler.java:106) 在 android.os.Looper.loop(Looper.java:201) 在 android.app.ActivityThread.main(ActivityThread.java:6806) 在 java.lang.reflect.Method.invoke( native 方法) 在 com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:547) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:873)
最佳答案
您正在尝试通过应用程序的主要组件注入(inject) HomeModule
中提供的演示者。这是行不通的,因为您从未将 HomeModule
提供给您的 AppComponent
。 HomeModule
甚至不应该是 AppComponent
的一部分,因为它提供的东西(presenter 和 interactor)只在 fragment 存在时存在,这意味着它们存在于 fragment 范围内,不是应用范围。
您需要做的是创建另一个将注入(inject)到您的 fragment 中的组件,例如
@Component(
modules = [
(HomeModule::class)
]
)
interface HomeComponent {
fun inject(homeFragment: HomeFragment)
}
然后在您的 HomeFragment
中:
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
DaggerHomeComponent
.builder()
.homeModule(HomeModule(this))
.build()
.inject(this)
}
如果您需要应用程序范围内的东西(来自网络和应用程序模块),那么您可以像以前一样通过 AppComponent
注入(inject)它们。
关于android - Dagger2 Android DI - lateinit 属性尚未初始化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62200906/
我读到的有关 AdSense 的所有内容都表明我需要一个我确实计划获得的网站(博客、域等)。我只是不确定我想要的域名。 但是,我想继续前进,因为来自 Google 的地址验证信可能需要数周时间。 所以
我有一个支持成就的小游戏。游戏尚未发布,但我需要测试成就。我现在可以做,但只是部分做,例如,当我执行游戏中心应用程序时,它似乎总是在沙盒模式下运行,并且该游戏未在“游戏”选项卡中列出。所以,我看不出成
我有一个 MYSQL 表 1,并希望与表 2 创建一个简单的 UNION: SELECT SomeField FROM Table1 UNION SELECT SomeField FROM Table
我希望我的角色可重用且独立。为了可重用,每个角色都按照“单层抽象”范式进行重点工作。这导致了许多小的“原子”角色,在它们之上构建了多层协调角色以提供更复杂的抽象。 为了自包含,每个角色都应该声明它对其
这个脚本有问题:click here .目前它运行良好。但是,如果我通过 w3 验证器运行它,它就不是“有效的”。我也知道这是为什么,因为整个div都在一个链接内。 我想让这个工作完全一样,但也让它得
前言: 我的核心问题与这个非常相似:How can I write a clean Repository without exposing IQueryable to the rest of my a
我正在测试 Xcode 7 的新 UI 测试功能(在 WWDC 2015 视频“UI Testing in Xcode”中介绍)。 启动时,我的应用通过更新其垂直布局约束的值将“登录面板”设置为动画:
我想在 Rails 服务器上运行 Ruby,但某个 gem 不想安装。这个 rails 程序与 ruby 2.0 不兼容,所以我想使用我安装的 ruby 1.9.3,但是我不能再 bundle
大家好, 我的问题:我想为不存在的 IP 地址启动 (tftp) 服务器。该服务器适用于 USB/RNDIS,其 IP 地址本质上仅在存在实际网络流量时才存在 - 但我想“尽早”启动服务器(例如,当
据我所知,document.getElementById('myId') 只会查找文档中已有的 HTML 元素。假设我通过 JS 创建了一个新元素,但我还没有将它附加到文档主体,是否有一种方法可以像我
我刚刚写了这段代码: // Somewhere earlier, the equivalent of this happens. std::set a; std::set b; FillMeUp(a)
我已阅读 here关于 boost:bind 的工作原理,尤其是它 - 除了其他东西 - 生成如下内容: struct unspecified_type { ... some members ..
假设我的本地存储库当前是原点之后的一个提交。假设我在我的本地存储库中提交了一个与源不冲突的更改。如何在不首先从原点 pull/merge 更改的情况下将此更改推送到原点? 最佳答案 好的,所以你因为非
我这里有一个非常奇怪的问题...我继承了一个相当大的 ASP.NET 3.5 Webforms 元素,一个问题是当启动应用程序时,会显示登录页面 - 但没有任何样式。 ... 这是 Login.asp
我试图从 boost::spirit 规则定义的 Action 中引用一个(尚未)未知实例的成员,所以在伪代码中, 代替 double_[ref(rN) = _1]我正在寻找类似的东西 X** ppx
根据 Cast SDK Docs ,要在我需要的 Android 中使用 Cast SDK,Google Play Services Revision 15。 我在我的 SDK 管理器中没有看到 Re
我是一名优秀的程序员,十分优秀!