Я изменил текст в строке 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
Я пытался отменить орфографию, но больше не мог решить проблему.
Я сделал это один раз, но это сработало, когда я вернул текст обратно.
Я посмотрел на строку 127. в Main.java и прокомментировал это 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();
}
});