首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >NfcAdapter不可为空,但由@Provides @Singleton @javax.annotation.Nullable android.nfc.NfcAdapter提供

NfcAdapter不可为空,但由@Provides @Singleton @javax.annotation.Nullable android.nfc.NfcAdapter提供
EN

Stack Overflow用户
提问于 2018-06-19 20:47:56
回答 2查看 1.2K关注 0票数 3

我在通过我的Dagger模块返回可为空的NfcAdapter时遇到了问题。这就是它:

代码语言:javascript
复制
  @Provides
  @Singleton
  @Nullable
  public NfcAdapter provideNfcAdapter() {
    return NfcAdapter.getDefaultAdapter(context);
  }

然而,该项目无法构建,我收到错误消息:

错误: dagger.android.AndroidInjector.inject(T) android.nfc.NfcAdapter不可为空,但由@Provides @Singleton @javax.annotation.Nullable android.nfc.NfcAdapter提供

如何解决这个问题?我已经为我的BluetoothAdapter提供了类似的方法,它可以像预期的那样工作。

我尝试在我的活动中将其初始化如下:

代码语言:javascript
复制
var nfcAdapter: NfcAdapter? = null @Inject set
EN

回答 2

Stack Overflow用户

发布于 2018-10-02 03:31:00

您需要向该字段添加一个@Nullable注释。任何简单名称为"Nullable“的注释都可以,如the docsthe code中所列。

尽管您可以使用?标记Kotlin中的可空性,但这并不会将“可空”信息从Kotlin发布到Java:像Dagger这样的Java处理器无法读取类文件来确定字段是否可以为空。(这是possible through some Kotlin reflection,但从v2.17开始,Dagger不支持此功能。)尽管您的代码是安全的,Dagger无法通过读取字节码来确定这一点,因此它会抛出一个错误。

票数 4
EN

Stack Overflow用户

发布于 2018-09-24 20:05:33

简要回答

-->删除@Nullable

之所以会发生这种情况,是因为您将@Nullable注释放在了不能返回null的方法中。Android Studio告诉你NfcAdapter不能为空。删除@Nullable注释应该是可行的。

深度解释

在我的例子中,我在dagger 2模块中使用了这个方法。

代码语言:javascript
复制
@Provides
@Singleton
@Nullable
AuthenticationInterceptor provideInterceptor(@Nullable String authToken) {
    if (authToken != null) {
        return new AuthenticationInterceptor(authToken);
    } else {
        return null;
    }
}

我发现我的类AuthenticationInterceptor实现了拦截器

代码语言:javascript
复制
public class AuthenticationInterceptor implements Interceptor {
}

无法返回null (如果没有authToken,我会从中返回null ),然后AS会给我以下错误。

代码语言:javascript
复制
AuthenticationInterceptor is not nullable, but is being provided by @Provides @Singleton ...

我的方法没有返回null解决了这个问题。(删除@Nullable注释并排除返回null)。

代码语言:javascript
复制
@Provides
@Singleton
AuthenticationInterceptor provideInterceptor(@Nullable String authToken) {
    return new AuthenticationInterceptor(authToken);
}

结论

我这样做是因为我已经在活动中处理这些可以为空的事情了。在用户没有授权令牌的情况下,我甚至没有尝试进行改进调用。我只是让他签到。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50928857

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档