有人可以向我解释为什么我会收到java.lang.IllegalStateException:尝试点击按钮从数据库中获取数据时,无法执行活动的方法吗?
我的xml代码有一个像这样的onClick:
<Button
android:layout_width="0dip"
android:layout_height="wrap_content"
android:text="Delete"
android:id="@+id/btnDelete"
android:layout_weight="1"
android:onClick="onClick_DeleteAll"/>
我的主要活动代码:
public void onClick_DeleteAll(View view){
DBTools dbTools = new DBTools(getApplicationContext())
float total = dbTools.total();
}
我的数据库类(DBTools.java)代码:
public float total(){
float total = 0;
SQLiteDatabase db = getReadableDatabase();
Cursor cursor = db.rawQuery("SELECT Sum("+ PRICE +") FROM " + TABLE_ITEM_SELL, null);
if (cursor.moveToFirst()){
total = Float.parseFloat(cursor.getString(0));
}
return total;
}
我不知道错误是什么,因为只有当我尝试执行的方法才会返回数据时才会发生错误。与上面的代码一样,它返回float。
错误:
java.lang.IllegalStateException: Could not execute method of the activity
at android.view.View$1.onClick(View.java:3591)
at android.view.View.performClick(View.java:4084)
at android.view.View$PerformClick.run(View.java:16966)
at android.os.Handler.handleCallback(Handler.java:615)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.reflect.InvocationTargetException
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at android.view.View$1.onClick(View.java:3586)
at android.view.View.performClick(View.java:4084)
at android.view.View$PerformClick.run(View.java:16966)
at android.os.Handler.handleCallback(Handler.java:615)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at java.lang.StringToReal.parseFloat(StringToReal.java:285)
at java.lang.Float.parseFloat(Float.java:300)
at com.jcarlapp.carl.amystore.DBTools.total(DBTools.java:151)
at com.jcarlapp.carl.amystore.MainActivity.onClick_DeleteAll(MainActivity.java:306)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at android.view.View$1.onClick(View.java:3586)
at android.view.View.performClick(View.java:4084)
at android.view.View$PerformClick.run(View.java:16966)
at android.os.Handler.handleCallback(Handler.java:615)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4745)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
at dalvik.system.NativeStart.main(Native Method)
答案 0 :(得分:2)
由NPE
Caused by: java.lang.NullPointerException
at java.lang.StringToReal.parseFloat(StringToReal.java:285)
at java.lang.Float.parseFloat(Float.java:300)
at com.jcarlapp.carl.amystore.DBTools.total(DBTools.java:151)
似乎cursor.getString(0)
在方法总计中返回null
。
我假设表中没有行来计算总和。
答案 1 :(得分:1)
如果表格中没有任何数据,SUM(column)
将返回SQL NULL
。
getString()
列值上的 NULL
将返回Java null
。
parseFloat(null)
会导致异常。
在尝试解析之前,请考虑检查空值。