我在通过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
答案 0 :(得分:3)
您需要在字段中添加@Nullable
批注。如the docs和the 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 {
}
结论
之所以这样做,是因为我已经在活动中处理了这些可为空的事情。如果用户没有授权令牌,我什至没有尝试进行改造。我只是问他登录。