android.content.res.Resources$NotFoundException: Main 中的字符串资源 ID 致命异常

Posted

技术标签:

【中文标题】android.content.res.Resources$NotFoundException: Main 中的字符串资源 ID 致命异常【英文标题】:android.content.res.Resources$NotFoundException: String resource ID Fatal Exception in Main 【发布时间】:2013-02-17 22:09:37 【问题描述】:

我一直在尝试制作一个简单的程序来获取一个小的随机数并在文本视图中显示给用户。在最终获得随机数生成(我认为)之后,每当我运行时,程序都会抛出一个致命的异常。代码没有错误,但我是一个完整的新手,我开始很简单,以便我可以学习。几个小时后,我已经提交请求帮助。我几乎可以肯定我的随机数 sn-p 是在错误的区域,我只是不知道把它放在哪里。我尝试的所有地方都会引发相同的错误。

这是.java

package com.eai.vgp;

import java.util.Random;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.widget.TextView;

public class MainActivity extends Activity 

    @Override
    protected void onCreate(Bundle savedInstanceState) 
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

    

    @Override
    public boolean onCreateOptionsMenu(Menu menu) 
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.activity_main, menu);
        return true;

    


    Random pp = new Random();
int a1 = pp.nextInt(10);

TextView tv = (TextView)findViewById(R.id.tv);

tv.setText(a1);

    

XML

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
tools:context=".MainActivity" >

<TextView
    android:id="@+id/tv"
    android:layout_
    android:layout_
    android:layout_centerHorizontal="true"
    android:layout_centerVertical="true" />

</RelativeLayout>

LogCat

03-03 16:34:25.313: I/Process(740): Sending signal. PID: 740 SIG: 9
03-03 16:35:02.212: E/Trace(806): error opening trace file: No such file or directory     (2)
03-03 16:35:02.802: W/ResourceType(806): No package identifier when getting value for     resource number 0x00000001
03-03 16:35:02.813: D/AndroidRuntime(806): Shutting down VM
03-03 16:35:02.813: W/dalvikvm(806): threadid=1: thread exiting with uncaught exception     (group=0x40a13300)
03-03 16:35:02.833: E/AndroidRuntime(806): FATAL EXCEPTION: main
03-03 16:35:02.833: E/AndroidRuntime(806): java.lang.RuntimeException: Unable to start     activity ComponentInfocom.eai.vgp/com.eai.vgp.MainActivity:     android.content.res.Resources$NotFoundException: String resource ID #0x1
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2059)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2084)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.app.ActivityThread.access$600(ActivityThread.java:130)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.app.ActivityThread$H.handleMessage(ActivityThread.java:1195)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.os.Handler.dispatchMessage(Handler.java:99)
03-03 16:35:02.833: E/AndroidRuntime(806):  at android.os.Looper.loop(Looper.java:137)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.app.ActivityThread.main(ActivityThread.java:4745)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     java.lang.reflect.Method.invokeNative(Native Method)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     java.lang.reflect.Method.invoke(Method.java:511)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
03-03 16:35:02.833: E/AndroidRuntime(806):  at dalvik.system.NativeStart.main(Native     Method)
03-03 16:35:02.833: E/AndroidRuntime(806): Caused by:     android.content.res.Resources$NotFoundException: String resource ID #0x1
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.content.res.Resources.getText(Resources.java:229)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.widget.TextView.setText(TextView.java:3620)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     com.eai.vgp.MainActivity.onCreate(MainActivity.java:22)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.app.Activity.performCreate(Activity.java:5008)
03-03 16:35:02.833: E/AndroidRuntime(806):  at     android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1079)
03-03 16:35:02.833: E/AndroidRuntime(806):      atandroid.app.ActivityThread.performLaunchActivity(ActivityThread.java:2023)
03-03 16:35:02.833: E/AndroidRuntime(806):  ... 11 more
03-03 16:35:05.113: I/Process(806): Sending signal. PID: 806 SIG: 9

【问题讨论】:

LogCat 错误,即应用程序崩溃时弹出的红线,是您最有价值的工具之一。你越早学会解释 LogCat,你就会学得越快。 :) 我添加了 logcat 文本。我仔细查看并感到困惑,以至于当我试图解决问题时,我得到了一些 R 无法解决的问题,而这本身就是一个小时的修复。 :S lol 从 html 和 CSS 跳转到 java 对我来说是一个巨大的跳跃。对不起!我想!哈哈。 【参考方案1】:

移动

Random pp = new Random();
int a1 = pp.nextInt(10);
TextView tv = (TextView)findViewById(R.id.tv);
tv.setText(a1);

onCreate()里面,把tv.setText(a1);改成tv.setText(String.valueOf(a1));

@Override
protected void onCreate(Bundle savedInstanceState) 
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);

  Random pp = new Random();
  int a1 = pp.nextInt(10);

  TextView tv = (TextView)findViewById(R.id.tv);
  tv.setText(String.valueOf(a1));

   

第一个问题:findViewById()onCreate() 之前被调用,这会引发 NPE。

第二个问题:将 int 直接传递给 TextView 会调用查找 String 资源的重载方法(来自 R.string)。因此,我们要使用String.valueOf()来强制String重载方法。

【讨论】:

@EricAnthony 不仅仅是staticStrings,一般来说只是任何Strings。问题是setText() 可以接受intString。如果您传递int,Android 会尝试从Strings.xml 中查找预编译字符串的 id,并且 99% 的情况下会失败。欲了解更多信息,请阅读overloaded methods。但是你的最后一句话是正确的,如果你想打印 不是 字符串的东西,你想使用String.valueOf(),这是最干净的方式。 @A--C 在字符串中使用 == 是 Java 新手最常犯的错误,因为这是最不令人意外的方法。同样,当您使用数字设置文本时,您希望使用数字设置文本。这两种常见用例都是新开发人员的明显选择,但都是错误的。因此我的评论。当我阅读我的评论时,我的意图并不明确.. 对此感到抱歉.. @A--C 很棒的解释! "" + a1 也会完成这项工作。 @Jimeux 正确,但我在示例中使用了valueOf(),因为它通常是better approach。【参考方案2】:

你试图做 a.setText(a1)。 a1 是一个 int 值,但 setText() 需要一个字符串值。出于这个原因,您需要使用 String.valueOf(a1) 将 a1 的值作为 String 而不是作为 int 传递给 a.setText(),如下所示:

a.setText(String.valueOf(a1))

这就是我的案例问题的确切解决方案。

【讨论】:

如果您添加一点解释或评论,这个答案会更清楚。谢谢! 我收到了同样的错误信息。当我添加 String.valueOf() 时,错误已得到纠正。 好的,int 重载查找资源 ID,知道了。【参考方案3】:
tv.setText( a1 + " ");

这将解决您的问题。

【讨论】:

【参考方案4】:

您正在尝试将 int 值设置为 TextView,因此您遇到了这个问题。 要解决此问题,请尝试以下一个选项

选项 1:

tv.setText(no+"");

选项2:

tv.setText(String.valueOf(no));

【讨论】:

【参考方案5】:

其他可能的解决方案:

tv.setText(Integer.toString(a1));  // where a1 - int value

【讨论】:

【参考方案6】:

这总是可能发生在 DataBinding 中。尽量不要在绑定中添加逻辑,包括附加一个空字符串。您可以制作自己的自定义适配器,并多次使用它。

@BindingAdapter("numericText")
fun numericText(textView: TextView, value: Number?) 
    value?.let 
        textView.text = value.toString()
    

&lt;TextView app:numericText="@list.size()" .../&gt;

【讨论】:

以上是关于android.content.res.Resources$NotFoundException: Main 中的字符串资源 ID 致命异常的主要内容,如果未能解决你的问题,请参考以下文章