场景:在我的应用程序中,我有来自我的演示者需要的不同数据源的不同类型的模型,例如UserState和任务。我为这两个模型创建了两个独立的存储库,即UserStateRepository和TaskRepository。
这两种信息都注入到TaskPresenter中,以便根据两个存储库中的数据显示任务和用户特定的信息。
事实上,这只是一种情况。我的应用程序有很多这样的模型,例如字典、参考资料等等。几乎每个视图演示者都需要两个注入的存储库: UserStateRepository和“MetaInformation”存储库。因此,我至少有7个不同的存储库。
PS: I使用Dagger2注入这些存储库,但只有用户状态存储库是应用程序级别的单子,而其他存储库通常具有活动级别范围。这是因为每次创建活动的新实例时,我都需要刷新其他活动作用域存储库的缓存,但是用户状态必须保持不变。
的问题是:这个体系结构真的有意义吗?还是有更好的解决方案?另外,如何处理这些存储库的不同生命周期?
发布于 2017-08-08 11:48:14
基本上,是的,每个实体都有一个存储库是个好主意。
但在你不需要的时候可能会有这样的情况。例如,您有一个实体用户,其中有Address实体。当您不需要将Address作为单独的实体处理时,可能会出现这种情况,相反,您可以将地址作为用户实体的一部分。因此,在这种情况下,为用户创建一个存储库就足够了,而不是为地址而设。
https://stackoverflow.com/questions/44822133
复制相似问题