gpt4 book ai didi

Android SQLite ContextWrapper.openOrCreateDatabase() 空指针?

转载 作者:行者123 更新时间:2023-11-30 04:48:31 30 4
gpt4 key购买 nike

我创建了一个带有服务的程序 - 该服务是“START_STICKY”。因此,当我关闭程序(我正在使用 Advanced Task Killer 来终止程序)时,服务会自动重新启动,但这会出现问题,因为我在尝试调用时遇到错误:

ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203) (see stacktrace below).

我已经创建了一个类来处理上下文,如果它不为空,它将返回我的 Activity 的上下文,或者如果 Activity 的上下文为 null,则返回我创建的假的 - 而 Activity 的上下文为 null,所以使用假的,我怀疑这可能是问题所在,但不知道。在我的 Activity 中,我有一个构造函数,它为 contexthandling 类提供了它自己的引用,但是当系统重新启动我的时, Activity 似乎没有实例化(至少在服务启动之前)服务。

程序刚正常启动时当然没有问题,服务启动正常;这就是我怀疑假上下文的原因,我按如下方式创建了它(它在带有 android:name=FakeContext 的 list 应用程序标记中被引用):

public class FakeContext extends android.app.Application 
{
private static FakeContext m_instance = null;

public FakeContext()
{
}

public static synchronized Context getContext()
{
if(m_instance == null)
{
m_instance = new FakeContext();
}

return m_instance;
}
}

堆栈跟踪:

11-18 19:12:14.048: ERROR/AndroidRuntime(15655): FATAL EXCEPTION: main
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): java.lang.RuntimeException: Unable to create service sdo.GeoTracker.Services.DataService: java.lang.NullPointerException
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.app.ActivityThread.handleCreateService(ActivityThread.java:3140)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.app.ActivityThread.access$3300(ActivityThread.java:135)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2202)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.os.Handler.dispatchMessage(Handler.java:99)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.os.Looper.loop(Looper.java:144)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.app.ActivityThread.main(ActivityThread.java:4937)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at java.lang.reflect.Method.invokeNative(Native Method)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at java.lang.reflect.Method.invoke(Method.java:521)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at dalvik.system.NativeStart.main(Native Method)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): Caused by: java.lang.NullPointerException
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.content.ContextWrapper.openOrCreateDatabase(ContextWrapper.java:203)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.database.sqlite.SQLiteOpenHelper.getWritableDatabase(SQLiteOpenHelper.java:98)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at sdo.GeoTracker.DataAccess.SqlAdapter.<init>(SqlAdapter.java:51)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at sdo.GeoTracker.DataAccess.SqlAdapter.getInstance(SqlAdapter.java:61)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at sdo.GeoTracker.Services.DataService.startService(DataService.java:65)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at sdo.GeoTracker.Services.DataService.onCreate(DataService.java:40)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): at android.app.ActivityThread.handleCreateService(ActivityThread.java:3125)
11-18 19:12:14.048: ERROR/AndroidRuntime(15655): ... 10 more

非常感谢任何帮助!- 我是android开发的初学者,所以请把它说出来。

最佳答案

Application 类是 Android 框架的一部分,您不能仅使用构造函数等创建它。使用您应用的 Application 对象,而不是使用“假”对象

关于Android SQLite ContextWrapper.openOrCreateDatabase() 空指针?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4219486/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com