
我将应用程序转换为MVP架构,并发现Dagger 2在需要时注入依赖关系是有用的.我的应用需要与两个网络APIs(我自己和第三方API)进行通信.可能有时候要求我自己的API和第三方API可以同时发射.我正在使用Retrofit与这些APIs进行通信,并使用GSON进行串行/反序列化.
我以前做过什么
我创建了两个Retrofit RestAdapter,并在需要时使用服务定位器模式来获取它们. RestAdapter旨在用于我自己的API,包括GSONConverter与一些自定义的类型自适应,因为我不希望在应用程序中对我的响应进行1:1的JSON反序列化.另一个RestAdapter适用于第三方API,并使用另一个具有特定字段命名策略的GSONConverter.
问题
我试图使用DI而不是Service Locator来获取我的RestAdapter(和API接口).我的NetModule类设置如下
@Modulepublic class NetModule { private static final String MY_API_URL = "my_API_url"; private static final String THIRD_PARTY_API_URL = "third_party_API_url"; @ProvIDes @Singleton Cache provIDeOkhttpCache(Application application) { int cacheSize = 10 * 1024 * 1024; // 10 MiB return new Cache(application.getCacheDir(),cacheSize); } @ProvIDes @Singleton OkhttpClIEnt provIDeOkhttpClIEnt(Cache cache) { OkhttpClIEnt clIEnt = new OkhttpClIEnt(); clIEnt.setCache(cache); return clIEnt; } @ProvIDes @Singleton TypeAdapter<MyClass> provIDeMyAPITypeAdapter() { return new TypeAdapter<MyClass>() { // implementation ignored }; } @ProvIDes @named("myAPIGson") Gson provIDeGsonForMyAPI(TypeAdapter<MyClass> adapter) { return new GsonBuilder() .registerTypeAdapter(MyClass.class,adapter) .setDateFormat("yyyy-MM-dd HH:mm:ss") .create(); } @ProvIDes @named("thirdPartyAPIGson") Gson provIDeGsonForThirdPartyAPI() { return new GsonBuilder() .setFIEldNamingPolicy(FIEldNamingPolicy.LOWER_CASE_WITH_UNDERscoreS) .create(); } @ProvIDes @named("myAPIRestAdapter") RestAdapter provIDeMyRestAdapter(Gson gson,OkhttpClIEnt okhttpClIEnt) { return new RestAdapter.Builder() .setEndpoint(MY_API_URL) .setConverter(new GsonConverter(gson)) .setClIEnt(new OkClIEnt(okhttpClIEnt)) .build(); } @ProvIDes @named("thirdPartyAPIRestAdapter") RestAdapter provIDeThirdPartyRestAdapter(Gson gson,OkhttpClIEnt okhttpClIEnt) { return new RestAdapter.Builder() .setEndpoint(THIRD_PARTY_API_URL) .setConverter(new GsonConverter(gson)) .setClIEnt(new OkClIEnt(okhttpClIEnt)) .build(); } @ProvIDes @Singleton MyAPI provIDeMyAPI(RestAdapter adapter){ return adapter.create(MyAPI.class); } @ProvIDes @Singleton ThirdPartyAPI provIDeThirdPartyAPI(RestAdapter adapter){ return adapter.create(ThirdPartyAPI.class); }} 从代码中可以看出,NetModule具有返回两个Gson对象和两个RestAdapter对象的方法.我的问题是
>如何确保在创建特定的RestAdapter和amp时注入正确的依赖关系API接口? (provIDeMyRestAdapter()需要从provIDeGsonForMyAPI()返回的GSON,并且provIDeMyAPI()需要从provIDeMyRestAdapter()返回的RestAdapter)
>如何确保在应用程序的生命周期内只有两个RestAdapter实例(一个用于我的API和另一个用于第三方API),因为创建RestAdapter是昂贵的.我在返回RestAdapters的方法上使用@named属性.例如,当直接注入依赖于字段的这种情况:@Inject(“myAPIRestAdapter”)RestAdapter myRestadapter;匕首2是每次创建新的RestAdapter还是要使用之前创建的(如@Singleton,但是对于特定对象)?
我刚刚开始使用Dagger 2,我对如何使用它的理解可能仍然是不正确的.如果我在这里做错事,请纠正我.感谢您提出这个长期的问题.
解决方法 您已经在解决方案的中间了.要完成解决方案,请尝试执行以下 *** 作:@ProvIDes@named("myAPIRestAdapter")RestAdapter provIDeMyRestAdapter(@named("myAPIGson") Gson gson,OkhttpClIEnt okhttpClIEnt) { return new RestAdapter.Builder() .setEndpoint(MY_API_URL) .setConverter(new GsonConverter(gson)) .setClIEnt(new OkClIEnt(okhttpClIEnt)) .build();}@ProvIDes@named("thirdPartyAPIRestAdapter")RestAdapter provIDeThirdPartyRestAdapter(@named("thirdPartyAPIGson") Gson gson,OkhttpClIEnt okhttpClIEnt) { return new RestAdapter.Builder() .setEndpoint(THIRD_PARTY_API_URL) .setConverter(new GsonConverter(gson)) .setClIEnt(new OkClIEnt(okhttpClIEnt)) .build();} 为了确保在应用程序的生命周期中只创建了两个RestAdapters实例,请注意两个提供RestAdapter的方法与@Singleton,就像您已经完成了其他方法一样.至于你的另一个问题,Dagger 2是否会在每次注入RestAdapter时创建新的实例,我认为它完全是这样,但我不确定.
希望这可以帮助!
总结以上是内存溢出为你收集整理的android – Dagger 2注入相同对象类型的多个实例全部内容,希望文章能够帮你解决android – Dagger 2注入相同对象类型的多个实例所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)