我在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();
}
});
答案 0 :(得分:4)
尝试以下
我发现有时R文件不会重建,这会有所帮助。
答案 1 :(得分:2)
您是否在项目中使用了硬编码的appname或packege名称 - 文件夹,数据库,内容提供商,自定义控件等。在您的情况下,我要做的是搜索整个项目中的旧值(Ctrl + H,FileSearch tab)看起来有问题。
编辑:也需要从设备/模拟器卸载应用程序(或清除用户数据,但我更喜欢完全卸载)。