为什么这个调用堆栈如此奇怪?

时间:2015-07-31 13:53:22

标签: java android callstack

今天我正在调试我的Android应用程序,它崩溃了。这是调用堆栈:

android.content.res.Resources$NotFoundException: String resource ID #0x8822
        at android.content.res.Resources.getText(Resources.java:246)
        at android.widget.TextView.setText(TextView.java:3860)
        at com.whackanandroid.GameActivity.gameOver(GameActivity.java:68)
        at com.whackanandroid.Game$1.onCountDownFinished(Game.java:79)
        at com.whackanandroid.CountDown$1.run(CountDown.java:23)
        at android.os.Handler.handleCallback(Handler.java:730)
        at android.os.Handler.dispatchMessage(Handler.java:92)
        at android.os.Looper.loop(Looper.java:213)
        at android.app.ActivityThread.main(ActivityThread.java:5225)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:525)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:741)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:557)
        at dalvik.system.NativeStart.main(Native Method)

然后我点击了行号链接(TextView.java:3860),它带我去了一行javadoc评论。我真的很困惑。评论从不执行。这不可能是错的。这很奇怪。

这是我的代码:

public void gameOver () {
    tvScore.setText (Integer.toString (Game.getInstance ().getScore ()));
    tvHighscore.setText (Game.getInstance ().getHighscore ());
    tvScoreText.setVisibility (View.VISIBLE);
    tvScore.setVisibility (View.VISIBLE);

    Animation anim = AnimationUtils.loadAnimation (this, R.anim.cover_fade_in);
    anim.setAnimationListener (new Animation.AnimationListener () {
        @Override
        public void onAnimationStart(Animation animation) {
            GameActivity.this.cover.setVisibility (View.VISIBLE);
        }

        @Override
        public void onAnimationEnd(Animation animation) {
            GameActivity.this.cover.setVisibility (View.VISIBLE);
            Game.InitializeGame (GameActivity.this);
            cover.setVisibility (View.VISIBLE);
        }

        @Override
        public void onAnimationRepeat(Animation animation) {

        }
    });
    cover.startAnimation (anim);
}

tvHighscore.setText (Game.getInstance ().getHighscore ());指的是调用堆栈中的行:at com.whackanandroid.GameActivity.gameOver(GameActivity.java:68)。我想这可能是因为tvHighscore的父视图,LinearLayoutGONE。这有关系吗?或者我做错了什么?

如果您需要查看更多代码,请随时问我。

3 个答案:

答案 0 :(得分:5)

  

或者我做错了什么?

是。您调用了setText(int),其值不是字符串资源ID。变化:

tvHighscore.setText (Game.getInstance ().getHighscore ());

为:

tvHighscore.setText(Integer.toString(Game.getInstance().getHighscore()));

答案 1 :(得分:0)

如果jar作为依赖项被拉入并且你正在调试那么这些行来自编译器创建的类文件,而不是java类,它必须自己输入方法名和其他信息。您不能总是依赖行号。

另一个原因可能是您使用的当前源的不同版本,以查看行号和引入的jar是不同的版本。

答案 2 :(得分:0)

问题是您使用带有整数参数的setText,这意味着资源ID。

要解决您的问题,您可以这样做:

tvHighscore.setText(""+Game.getInstance().getHighscore());