Android更改了app_name字符串,现在它崩溃了

时间:2011-11-28 11:43:34

标签: android string android-activity crash main

我在app_name字符串中更改了文本(只是想修复拼写)。 当我运行项目时,它返回了一场灾难:

11-15 18:20:13.181: W/dalvikvm(926): threadid=1: thread exiting with uncaught exception (group=0x40015560)
11-15 18:20:13.211: E/AndroidRuntime(926): FATAL EXCEPTION: main
11-15 18:20:13.211: E/AndroidRuntime(926): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.dreamoholic.android.smartshoppinglist/com.dreamoholic.android.smartshoppinglist.Main}: java.lang.NullPointerException
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1647)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.app.ActivityThread.access$1500(ActivityThread.java:117)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.os.Handler.dispatchMessage(Handler.java:99)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.os.Looper.loop(Looper.java:123)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.app.ActivityThread.main(ActivityThread.java:3683)
11-15 18:20:13.211: E/AndroidRuntime(926):  at java.lang.reflect.Method.invokeNative(Native Method)
11-15 18:20:13.211: E/AndroidRuntime(926):  at java.lang.reflect.Method.invoke(Method.java:507)
11-15 18:20:13.211: E/AndroidRuntime(926):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
11-15 18:20:13.211: E/AndroidRuntime(926):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
11-15 18:20:13.211: E/AndroidRuntime(926):  at dalvik.system.NativeStart.main(Native Method)
11-15 18:20:13.211: E/AndroidRuntime(926): Caused by: java.lang.NullPointerException
11-15 18:20:13.211: E/AndroidRuntime(926):  at com.dreamoholic.android.smartshoppinglist.Main.onCreate(Main.java:127)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047)
11-15 18:20:13.211: E/AndroidRuntime(926):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
11-15 18:20:13.211: E/AndroidRuntime(926):  ... 11 more

我试图撤消拼写但无法解决问题。 我曾经这样做了一次,但是当我改回文本时它就起作用了。

我查看了Main.java中的127.行并注释掉了onClickListener,但它只是转到另一行并在那里发出错误。

这是我的清单:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.dreamoholic.android.smartshoppinglist"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk android:minSdkVersion="7" />
    <uses-permission android:name="android.permission.WAKE_LOCK"/>
    <uses-permission android:name="android.permission.DISABLE_KEYGUARD"/>

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:label="@string/app_name"
            android:name=".Main"
            android:configChanges="keyboardHidden|orientation">
            <intent-filter >
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".Saved"
            android:configChanges="keyboardHidden|orientation">
        </activity>
        <activity android:name=".List"
            android:configChanges="keyboardHidden|orientation">
        </activity>
    </application>

</manifest>

这是我的strings.xml:

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <string name="hello">Hello World, Main!</string>
    <string name="app_name">Smart Shopping List</string>
    <!-- strings for Main top row -->
    <string name="main_new">New</string>
    <string name="main_popular">Popular</string>
    <string name="main_saved">Saved</string>
    <string name="main_send">Send</string>
</resources>

我不知道如何解决这个问题。 我试图复制项目,清理它并手工复制到另一个新项目中。

我在创建新项目时搞砸了我的包名。 现在我检查了所有包名,它们是一致的。

首先我在我的127.行上收到错误:

            tv3.setOnClickListener(new OnClickListener() {

                @Override
                public void onClick(View v) {

                    Toast.makeText(Main.this, theme, Toast.LENGTH_SHORT).show();

                }
            });

2 个答案:

答案 0 :(得分:4)

尝试以下

  • 清理您的项目(项目 - &gt;清洁)
  • 右键单击您的项目 - &gt; Android工具 - &gt;修复项目属性

我发现有时R文件不会重建,这会有所帮助。

答案 1 :(得分:2)

您是否在项目中使用了硬编码的appname或packege名称 - 文件夹,数据库,内容提供商,自定义控件等。在您的情况下,我要做的是搜索整个项目中的旧值(Ctrl + H,FileSearch tab)看起来有问题。

编辑:也需要从设备/模拟器卸载应用程序(或清除用户数据,但我更喜欢完全卸载)。