【问题标题】:Android mysterious null pointer exceptionAndroid神秘的空指针异常
【发布时间】:2013-04-16 00:21:47
【问题描述】:

自从我上传了我的应用程序后,我收到了许多 java.lang.NullPointerException 崩溃报告。我正在努力理解这个问题,因为它不会在模拟器或我亲自测试过的物理设备上崩溃。以下是其中一份报告的示例:

java.lang.IllegalStateException: Could not execute method of the activity
at android.view.View$1.onClick(View.java:2072)
at android.view.View.performClick(View.java:2408)
at android.view.View$PerformClick.run(View.java:8817)
at android.os.Handler.handleCallback(Handler.java:587)
at android.os.Handler.dispatchMessage(Handler.java:92)
at android.os.Looper.loop(Looper.java:143)
at android.app.ActivityThread.main(ActivityThread.java:4914)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.reflect.InvocationTargetException
at com.bryan.barrett.countdownforandroid.practiceSubscreen.openNumbersSelect(Unknown         Source)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at android.view.View$1.onClick(View.java:2067)
... 11 more
Caused by: java.lang.NullPointerException
... 15 more

我认为当按下“openNumbersSelect”按钮时,这会在“practiceSubscreen”中崩溃。这是我对该按钮的一段代码:

public void openNumbersSelect(View view){
    Intent iNum = new Intent(this, numbersSelect.class);
    String gamemode = "practice";   //practice mode
    iNum.putExtra("gamemode", gamemode);
    startActivity(iNum);

    overridePendingTransition(R.anim.fadein, R.anim.fadeout);
    if(sound){
        soundPool.play(Main.SNDclick, audio.getStreamVolume(AudioManager.STREAM_MUSIC), 
                audio.getStreamVolume(AudioManager.STREAM_MUSIC), 1, 0, 1f);
    }
} 

这是要打开的以下 numbersSelect 类中的 onCreate 代码:

public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_numbers_select);

        Intent i = getIntent();
        gamemode = i.getStringExtra("gamemode");    
        gameround = i.getIntExtra("gameround", 0) + 1;
        points = i.getIntExtra("points", 0);    

        //Shared Preferences
        prefs = PreferenceManager.getDefaultSharedPreferences(this);
        sound = prefs.getBoolean("sound", true);

        //Sounds
        setVolumeControlStream(AudioManager.STREAM_MUSIC);
        audio = (AudioManager) getSystemService(Context.AUDIO_SERVICE);
        soundPool = Main.soundPool;

        //Big Numbers
        for (int n=25; n<=100; n+=25){      //add 25, 50, 75, 100
            bignumbers.add(n);              
        }
        //Small Numbers
        for (int m=1; m<=10; m++){      //adds 1-10 twice
            smallnumbers.add(m); 
            smallnumbers.add(m); 
        }

        //Screen metrics
        DisplayMetrics metrics = new DisplayMetrics();
        getWindowManager().getDefaultDisplay().getMetrics(metrics);
        int screenw = metrics.widthPixels; int screenh = metrics.heightPixels;
        int unitw = (screenw/14); int unith = (screenh/40); //divide screen into 14 columns x 40 rows...

        num1 = (Button)findViewById(R.id.num1img); nums.add(num1); 
        num2 = (Button)findViewById(R.id.num2img); nums.add(num2); 
        num3 = (Button)findViewById(R.id.num3img); nums.add(num3); 
        num4 = (Button)findViewById(R.id.num4img); nums.add(num4); 
        num5 = (Button)findViewById(R.id.num5img); nums.add(num5); 
        num6 = (Button)findViewById(R.id.num6img); nums.add(num6); 
        for(int n=0; n<6; n++){
            nums.get(n).setHeight(screenh/4); nums.get(n).setTextSize(Main.fontSize); 
            nums.get(n).setWidth(screenw/6); nums.get(n).setPadding(1, 1, 1, 1);
        }
        lrg = (Button)findViewById(R.id.largebutton); lrg.setWidth((unitw*200)/35); 
        sml = (Button)findViewById(R.id.smallbutton); sml.setWidth((unitw*200)/35);

        Typeface scribble = Typeface.createFromAsset(getAssets(), "fonts/scribble.ttf");

        TextView numbersSeltext = (TextView)findViewById(R.id.numbersSeltext);
        numbersSeltext.setTypeface(scribble);
        numbersSeltext.setWidth(screenw); numbersSeltext.setHeight(unith*8);
        if(gamemode.equals("full")){
            numbersSeltext.setText("Round " + gameround + ": Select 6 Numbers");
        }
}

如果有人能对此有所了解,将不胜感激!这是一个令人沮丧的问题,因为它在我自己测试过的设备上运行良好,而且根据反馈,它似乎在很多设备上运行良好,所以我什至不确定代码是否存在问题,或者某些设备是否存在问题已构建.. 如果需要,我可以抛出更多崩溃报告或代码!

提前致谢!

【问题讨论】:

  • 您能否展开堆栈跟踪中显示... 15 more 的部分并将其添加到问题中?这可能会有所帮助。
  • 跟踪中的那些“... XX more”消息是多余的。堆栈跟踪之前没有显示任何内容。
  • show onCreate of numberSelect Class
  • @StinePike 我已编辑问题以包含 numbersSelect 类的 onCreate。任何指导都会有所帮助,因为我完全不知所措!

标签: android crash null nullpointerexception illegalstateexception


【解决方案1】:

如果我是你,我会在使用之前测试所有 Buttons num1,num2... 和许多其他视图是否为 null,因为如果视图尚未创建存在,那么简单地获取视图可能会引发 nullpointerexception无论出于何种原因(例如,可滚动的列表视图项仅填充可以放入屏幕的视图)。如果您让用户知道您的布局 xml 是什么,它可能会有所帮助。

【讨论】:

  • 感谢您的回复。我有一个线性布局的按钮来容纳 6 个数字按钮,全局视图组是一个相对布局。我对大多数屏幕使用相对布局,在这个阶段我收到了几乎每个屏幕的崩溃报告。我忘了提到一个奇怪的行为,有时当我从 Eclipse 运行应用程序时,视图大小都是错误的(在大多数情况下,我在 onCreate 中定义了大小,并且好像没有被调用或其他东西)。我想知道这和它有什么关系吗?它很少发生,但不止一次发生@Neoh
  • 您的错误报告并未反映真正的错误来源。如果有的话,“Caused by: java.lang.NullPointerException ... 15 more”下面的行是什么?您应该查看主要来源。
  • 这就是崩溃报告给出的所有内容,我无法再扩展 15 个部分。我已经彻底检查了我的代码,但找不到任何传递的空值。这是非常奇特的,它从来没有对我(中兴刀片)崩溃,并且当我检查时没有关于 Galaxy S3 崩溃的报告(2800 次下载到 s3 并且没有一个 s3 崩溃报告,即使我有近 200 份报告这个 nullPointerException)。我会调查其他设备,它在 nexus 7 上崩溃了,但对于某些人来说,它在他们的 nexus 7 上运行良好。@Neoh