android:在服务上尝试sqlite数据库时强制关闭

标签 android sqlite service

我想从服务中的 sqlite 数据库中获取 RawCount,但出现错误。

这是我的服务类代码:

public int onStartCommand(Intent intent, int flags, int startId) {

    database_center helper = null;
    Cursor cursor;

    SQLiteDatabase db = helper.getReadableDatabase();
    cursor = db.rawQuery("select * from list", null);
    int rawCount = cursor.getCount();

    Toast.makeText(this, "The Service Started. Count  "+rawCount, Toast.LENGTH_LONG).show();

    return START_STICKY;
}

日志猫:

08-12 22:47:51.421: E/AndroidRuntime(13053): 致命异常: main 08-12 22:47:51.421: E/AndroidRuntime(13053): java.lang.RuntimeException: 无法启动服务 com.example.belService.theService@416d5818 with Intent { cmp=com.example.belService/.theService }: java.lang.NullPointerException异常 08-12 22:47:51.421: E/AndroidRuntime (13053): 在 android.app.ActivityThread.handleServiceArgs (ActivityThread.java:2575) 08-12 22:47:51.421: E/AndroidRuntime(13053): 在 android.app.ActivityThread.access$2000(ActivityThread.java:143) 08-12 22:47:51.421: E/AndroidRuntime(13053): 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1338) 08-12 22:47:51.421: E/AndroidRuntime (13053): 在 android.os.Handler.dispatchMessage (Handler.java:99) 08-12 22:47:51.421: E/AndroidRuntime(13053): 在 android.os.Looper.loop(Looper.java:137) 08-12 22:47:51.421: E/AndroidRuntime(13053): 在 android.app.ActivityThread.main(ActivityThread.java:4963) 08-12 22:47:51.421:E/AndroidRuntime(13053):在 java.lang.reflect.Method.invokeNative( native 方法) 08-12 22:47:51.421: E/AndroidRuntime(13053): 在 java.lang.reflect.Method.invoke(Method.java:511) 08-12 22:47:51.421:E/AndroidRuntime(13053):在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1038) 08-12 22:47:51.421: E/AndroidRuntime (13053): 在 com.android.internal.os.ZygoteInit.main (ZygoteInit.java:805) 08-12 22:47:51.421:E/AndroidRuntime(13053):在 dalvik.system.NativeStart.main( native 方法) 08-12 22:47:51.421: E/AndroidRuntime(13053): 由 java.lang.NullPointerException 引起 08-12 22:47:51.421: E/AndroidRuntime(13053): 在 com.example.belService.theService.onStartCommand(theService.java:48) 08-12 22:47:51.421: E/AndroidRuntime(13053): 在 android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2558)

最佳答案

database_center helper = null;
Cursor cursor;

SQLiteDatabase db = helper.getReadableDatabase();

变量 helper 在第 1 行被初始化为 null,此后从未改变;显然第 3 行会给出空异常,因为您在空对象上调用了方法 getReadableDatabase()

关于android:在服务上尝试sqlite数据库时强制关闭,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25268950/

相关文章:

android - 使用自定义样式时微调器导致错误

python - SQLITE3 - 将数据放入带有循环的列中

android - 异步任务和守护进程之间的区别

android - 将数据传递给 Service 的 onDestroy()

c# - 如何在 web.config 中引用 DLL?

android - flutter 闪屏不适用于launch_background.xml

android - React Native - 应用程序在实现 HMSCore 后启动时崩溃

mysql - Rails 制作数据库 mysql

android - 多个插入语句android sqlite

Android adb显示 "Allow USB debugging?"窗口