Android изменил строку app_name, теперь он вылетает - PullRequest
2 голосов
/ 28 ноября 2011

Я изменил текст в строке 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();

                }
            });

Ответы [ 2 ]

4 голосов
/ 28 ноября 2011

Попробуйте выполнить

  • очистить ваш проект (Проект -> Очистить)
  • щелкните правой кнопкой мыши свой проект -> Инструменты Android -> Исправить свойства проекта

Я обнаружил, что иногда файл R не перестраивается, и это помогает.

2 голосов
/ 28 ноября 2011

если бы вы использовали свое имя приложения или имя пакета в своем проекте, жестко закодированное - папки, базы данных, контент-провайдеры, пользовательские элементы управления и т. Д. В моем случае я бы выполнил поиск старого значения во всем проекте (Ctrl + H, FileSearch).вкладка) и посмотрите, есть ли что-то не так.

Редактировать: требуется также удаление приложения с устройства / эмулятора (или очистить данные пользователя, но я предпочитаю полное удаление).

...