android - 为什么在此活动中出现空对象错误?
问题描述
我正在使用改造来获取数据..我试图从小部件启动应用程序。但是由于 null 对象,应用程序正在崩溃。我尝试检查对象...从 API 获取数据后它不为空,但后来它变为空...为什么?有什么方法可以正确获取数据.. 小部件点击后应用程序如何获取数据?
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.master_list);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
//Checking to see if the app is opened by widget by checking existence of startFromWidget value from intent
if (getIntent().getExtras().getString("stringFromWidget") != null) {
//App opened by widget
fromWidget = true;
//Getting last stored value from Database assign it to temp
Cursor c = getContentResolver().query(DBContract.CONTENT_URI, null, null, null);
assert c != null;
c.moveToFirst();
String temp = c.getString(c.getColumnIndex(DBContract.RECIPE_NAME));
//Fetching data from API
ApiInterface apiService = ApiClient.getClient().create(ApiInterface.class);
Call<List<ApiResponce>> call = apiService.getResponce();
call.enqueue(new Callback<List<ApiResponce>>() {
@Override
public void onResponse(Call<List<ApiResponce>> call, Response<List<ApiResponce>> response) {
reciepeObject = response.body().get(3);
//Making sure data is received
Toast.makeText(MasterListClass.this, reciepeObject.getName(), Toast.LENGTH_SHORT).show();//No null object error ...working fine
}
@Override
public void onFailure(Call<List<ApiResponce>> call, Throwable t) {
Log.e("networkError", t.getMessage());
}
});
}
//if the app not opened by widget get the object from the intent
else {
reciepeObject = getIntent().getParcelableExtra(getString(R.string.object));
}
//Null Object error from recipeObject.getName().. why ?
getSupportActionBar().setTitle(reciepeObject.getName());
日志猫:
05-11 12:42:48.558 6978-6978/facebooklogintest.cavepass.com.bakingapp E/AndroidRuntime:致命异常:主进程:facebooklogintest.cavepass.com.bakingapp,PID:6978 java.lang.RuntimeException:无法启动活动ComponentInfo{facebooklogintest.cavepass.com.bakingapp/facebooklogintest.cavepass.com.bakingapp.UI.MasterListClass}:java.lang.NullPointerException:尝试调用虚拟方法'java.lang.String facebooklogintest.cavepass.com.bakingapp.ModelClasses。 ApiResponce.getName()' 在 android.app.ActivityThread 的空对象引用上。performLaunchActivity(ActivityThread.java:2817) at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2892) at android.app.ActivityThread.-wrap11(Unknown Source:0) at android.app.ActivityThread$H.handleMessage(ActivityThread .java:1593) 在 android.os.Handler.dispatchMessage(Handler.java:105) 在 android.os.Looper.loop(Looper.java:164) 在 com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java: 240) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 引起:java.lang.NullPointerException:尝试调用虚拟方法'java.lang.String facebooklogintest.cavepass.com.bakingapp。ModelClasses.ApiResponce.getName()' 在 facebooklogintest.cavepass.com.bakingapp.UI.MasterListClass.onCreate(MasterListClass.java:100) 在 android.app.Activity.performCreate(Activity.java:6975) 的空对象引用上android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1213) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2770) 在 android.app。ActivityThread.handleLaunchActivity(ActivityThread.java:2892) at android.app.ActivityThread.-wrap11(Unknown Source:0) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1593) at android.os.Handler.dispatchMessage (Handler.java:105) 在 android.os.Looper.loop(Looper.java:164) 在 android.app.ActivityThread.main(ActivityThread.java:6541) 在 java.lang.reflect.Method.invoke(Native Method) 在 com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 在 com.android.internal.os.ZygoteInit.main( ZygoteInit.java:767) 05-11 12:42:48.621 2661-6708/com.google.android.googlequicksearchbox:search E/ContentStoreEUAS: 未能提交延迟操作 05-11 12:42:49.066 2057-2086/system_process E/ActivityManager: applyOptionsLocked: Unknown animationType=0在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 05-11 12 的 com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 调用(本机方法): 42:48.621 2661-6708/com.google.android.googlequicksearchbox:search E/ContentStoreEUAS: 未能提交延迟操作 05-11 12:42:49.066 2057-2086/system_process E/ActivityManager: applyOptionsLocked: Unknown animationType=0在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:767) 05-11 12 的 com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:240) 调用(本机方法): 42:48.621 2661-6708/com.google.android.googlequicksearchbox:search E/ContentStoreEUAS: 未能提交延迟操作 05-11 12:42:49.066 2057-2086/system_process E/ActivityManager: applyOptionsLocked: Unknown animationType=0java:767) 05-11 12:42:48.621 2661-6708/com.google.android.googlequicksearchbox:search E/ContentStoreEUAS: 未能提交延迟操作 05-11 12:42:49.066 2057-2086/system_process E/ ActivityManager:applyOptionsLocked:未知动画类型 = 0java:767) 05-11 12:42:48.621 2661-6708/com.google.android.googlequicksearchbox:search E/ContentStoreEUAS: 未能提交延迟操作 05-11 12:42:49.066 2057-2086/system_process E/ ActivityManager:applyOptionsLocked:未知动画类型 = 0
解决方案
移动
getSupportActionBar().setTitle(reciepeObject.getName());
里面onResponse
call.enqueue(new Callback<List<ApiResponce>>() {
@Override
public void onResponse(Call<List<ApiResponce>> call, Response<List<ApiResponce>> response) {
reciepeObject = response.body().get(3);
getSupportActionBar().setTitle(reciepeObject.getName());
//^^^^^^^^^^^^
Toast.makeText(MasterListClass.this, reciepeObject.getName(), Toast.LENGTH_SHORT).show();//No null object error ...working fine
}
@Override
public void onFailure(Call<List<ApiResponce>> call, Throwable t) {
Log.e("networkError", t.getMessage());
}
});
因为 REST 调用是异步的,所以需要一些时间才能完成,并且响应只能在onResponse
触发一次时使用
推荐阅读
- php - Ajax 请求不执行(完全是幽灵)
- angular - 在组件的方法中创建的对象的 TypeScript 测试属性
- sql - SQL 无法将 Varchar 转换为数值 - 转换失败错误
- php - 来自 laravel api 的外部 phpmyadmin
- javascript - 在映射的箭头函数中作为参数传递的对象中的键值分配
- android - 如果用户2手机的屏幕使用推送关闭,如何向用户1发送XMPP消息确认(双勾)?
- .net - dotnet 发布“无法加载源 https://api.nuget.org/v3/index.json 的服务索引”
- c - 从 Buff 加载文件
- docker - Eureka-client 无法调用另一个 Eureka-client,抛出 UnknownHostException
- python - 作为 Python 程序的一部分运行 OpenCV 脚本