Android活动上下文NullPointerException

时间:2014-02-20 00:27:23

标签: java android android-activity nullpointerexception android-context

我在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);

3 个答案:

答案 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()之类的呼叫,其中myObjnull。但是这个方法调用会在执行进入myMethod()之前抛出一个NPE。

这意味着您的错误来自其他地方。

答案 2 :(得分:0)

你介意发布完整的构造函数吗?空指针异常发生在Sync()构造函数内的某处。 _ctx虽然

,但不是空的