我在Google Play开发者控制台上有关于活动上下文或应用程序上下文中的NPE的一些奇怪的错误报告。我无法在我的设备上重新创建此错误,我知道它在大多数设备上都能正常工作。
这是我的主要活动,即首次在应用启动时打开的活动:
public class ActSplash extends Activity {
private Sync sync;
private Context ctx;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.act_splash);
do {
ctx = this.getApplicationContext(); //Using just "this" doesn't work either.
} while (ctx==null);
sync = Sync.getInstance(ctx); //Apparently ctx is null at this point in some devices
}
这是我的Sync类(Singleton)
public class Sync {
private Context ctx;
private static Sync INSTANCE = null;
public static Sync getInstance(Context ctx) {
if (INSTANCE == null) createInstance(ctx);
return INSTANCE;
}
private synchronized static void createInstance(Context ctx) {
if (INSTANCE == null) {
INSTANCE = new Sync(ctx);
}
}
private Sync(Context _ctx)
{
ctx = _ctx;
//NPE on following line
WifiManager wifiMan = (WifiManager) ctx.getSystemService(Context.WIFI_SERVICE);
...
}
这是堆栈跟踪:
java.lang.RuntimeException: Unable to start activity
ComponentInfo{com.xxx.xxx/com.xxx.xxx.ActSplash}: java.lang.NullPointerException
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2140)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2178)
at android.app.ActivityThread.access$700(ActivityThread.java:141)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1271)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5118)
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:792)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:555)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
at com.xxx.xxx.Sync.<init>(SourceFile:82)
at com.xxx.xxx.Sync.void createInstance(android.content.Context)(SourceFile:67)
at com.xxx.xxx.Sync.com.xxx.xxx.Sync getInstance(android.content.Context)(SourceFile:72)
at com.xxx.xxx.ActSplash.void onCreate(android.os.Bundle)(SourceFile:40)
at android.app.Activity.performCreate(Activity.java:5058)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2104)
... 11 more
在致电之前,我该怎么做才能确保ctx!=null
:
sync = Util_Sync.getInstance(ctx);
答案 0 :(得分:1)
因为您的代码不会改变
do {
ctx = this.getApplicationContext(); //Using just "this" doesn't work either.
} while (ctx==null);
如果它无法获得ctx
,这将导致无限循环。
活动是一个背景!见http://developer.android.com/reference/android/content/Context.html
已知的间接子类 AbstractInputMethodService,AccessibilityService,AccountAuthenticatorActivity,ActionBarActivity, Activity ,ActivityGroup,AliasActivity,Application,BackupAgent,BackupAgentHelper,ContextThemeWrapper以及其他23个。
尝试
ctx = this;
<强>更新强>
继续发布您的同步代码
private Context ctx;
从未使用过,因此请将其删除。
答案 1 :(得分:0)
请注意this
永远不会是null
。相反,它可以是,那么这意味着您将进行myObj.myMethod()
之类的呼叫,其中myObj
是null
。但是这个方法调用会在执行进入myMethod()
之前抛出一个NPE。
这意味着您的错误来自其他地方。
答案 2 :(得分:0)
你介意发布完整的构造函数吗?空指针异常发生在Sync()
构造函数内的某处。 _ctx
虽然