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

时间:2018-06-19 12:47:56

标签: java android kotlin annotations dagger

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

  @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提供了类似的提供方法,它可以按预期工作。

我尝试在“活动”中按如下所示对其进行初始化:

var nfcAdapter: NfcAdapter? = null @Inject set

2 个答案:

答案 0 :(得分:3)

您需要在字段中添加@Nullable批注。如the docsthe code中所列,任何具有简单名称“ Nullable”的注释都将起作用。

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

答案 1 :(得分:0)

简要答案

->删除class DateTimeForm(forms.Form): CUSTOM_FORMAT = '%m/%d/%y %I:%M %p' date_input = forms.DateTimeField(widget=forms.HiddenInput) def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) if self.CUSTOM_FORMAT not in self.fields['date_input'].input_formats: self.fields['date_input'].input_formats.append(self.CUSTOM_FORMAT)

之所以会这样,是因为您将.factory('sessionService', ['$http', function ($http) { var temp = {}; return { set: function (value) { temp = value; return localStorage.setItem("json_key", JSON.stringify(temp)); }, get: function () { temp = JSON.parse(localStorage.getItem("json_key")); return temp; }, destroy: function (key) { return localStorage.removeItem("json_key"); }, update: function(key, value) { temp.key = value; set(temp); return temp; } }; }]); 批注放在了不能返回null的方法中。 Android Studio告诉您@Nullable不能为null。删除@Nullable注释应该可以。

深入的解释

在我的情况下,我在匕首2模块中使用了此方法。

NfcAdapter

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

@Nullable

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

@Provides
@Singleton
@Nullable
AuthenticationInterceptor provideInterceptor(@Nullable String authToken) {
    if (authToken != null) {
        return new AuthenticationInterceptor(authToken);
    } else {
        return null;
    }
}

不从我的方法返回null即可解决此问题。 (删除@Nullable批注,并排除返回null)。

public class AuthenticationInterceptor implements Interceptor {
}

结论

之所以这样做,是因为我已经在活动中处理了这些可为空的事情。如果用户没有授权令牌,我什至没有尝试进行改造。我只是问他登录。