Исключение, когда я запускаю свое приложение из Eclipse - PullRequest
42 голосов
/ 17 марта 2012

У меня эта проблема уже почти 2 месяца, и я не могу ее решить. Проблема в том, что если мое приложение работает и я запускаю (переустанавливаю) свое приложение из Eclipse, я получаю сообщение об ошибке, указывающее, что мое приложение аварийно завершилось «К сожалению, остановилось». Я замечаю, что это также происходит, когда я запускаю его на своем ПК / Eclipse, я думаю, что это происходит только после того, как я не запускаю его некоторое время.

Это происходит только в том случае, если приложение активно в третьем действии (BaseDiagramActivity), а затем я снова запускаю приложение из Eclipse. Я удалил практически все приложения, кроме 3-х действий, и это все еще происходит.

Я искал и искал решение этой проблемы, но не могу найти ни одного хорошего ответа, или того, который подходит мне.

Это не похоже на аппаратную или андроидную версию, так как я запускаю это на своем планшете (4.0.3) и моем телефоне (4.0.2, происходило на 4.0.1 до обновления). Если, конечно, это ошибка сэндвича с мороженым.

Дайте мне знать, если потребуется дополнительная информация.

Исключение (Tag = AndroidRuntime)

FATAL EXCEPTION: main
java.lang.RuntimeException: Unable to instantiate application android.app.Application: java.lang.NullPointerException
   at android.app.LoadedApk.makeApplication(LoadedApk.java:482)
   at android.app.ActivityThread.handleBindApplication(ActivityThread.java:3938)
   at android.app.ActivityThread.access$1300(ActivityThread.java:123)
   at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1185)
   at android.os.Handler.dispatchMessage(Handler.java:99)
   at android.os.Looper.loop(Looper.java:137)
   at android.app.ActivityThread.main(ActivityThread.java:4424)
   at java.lang.reflect.Method.invokeNative(Native Method)
   at java.lang.reflect.Method.invoke(Method.java:511)
   at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
   at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
   at android.app.LoadedApk.initializeJavaContextClassLoader(LoadedApk.java:362)
   at android.app.LoadedApk.getClassLoader(LoadedApk.java:305)
   at android.app.LoadedApk.makeApplication(LoadedApk.java:474)
   ... 11 more

Код Android

LoadedApk.initializeJavaContextClassLoader () - строка 362 представляется нарушителем

Ниже приведены соответствующие файлы:

AndroidManifest.xml

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

    <uses-sdk android:minSdkVersion="14" />

    <application 
        android:icon="@drawable/ic_launcher" 
        android:label="@string/app_name" >
        <activity 
            android:name="HomeActivity" 
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="LoadDiagramActivity" android:label="Load Diagram"></activity>
        <activity android:name="BaseDiagramActivity" android:label="Base Diagram"></activity>
    </application>

</manifest>

HomeActivity.java

public class HomeActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        setContentView(R.layout.home);

        Button diagramButton = (Button)findViewById(R.id.diagram);
        diagramButton.setOnClickListener(new View.OnClickListener() {
            public void onClick(View v) {
                startActivity(new Intent(HomeActivity.this, LoadDiagramActivity.class));
            }
        });
    }
}

LoadDiagramActivity.java

public class LoadDiagramActivity extends Activity {

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        ActionBar actionBar = getActionBar();
        actionBar.setDisplayHomeAsUpEnabled(true);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        MenuInflater menuInflater = getMenuInflater();
        menuInflater.inflate(R.menu.load_diagram_menu, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        switch (item.getItemId()) {
            case android.R.id.home:
                finish();
                return true;
            case R.id.add_new_diagram:
                startActivity(new Intent(this, BaseDiagramActivity.class));
                return true;
            default:
                return super.onOptionsItemSelected(item);
        }
    }
}

BaseDiagramActivity.java

на самом деле не имеет значения, что это за действие, исключение происходит, пока запускается третье действие (или нажатие кнопки добавления на LoadDiagramActivity.

public class BaseDiagramActivity extends Activity {
}

home.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <Button
        android:id="@+id/diagram"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Diagram" />

</LinearLayout>

Дополнительная информация

Когда я сократил свой проект, чтобы попросить более простой ответ, я переместил все в пространство имен пакета. В реальном проекте есть 5 пространств имен, они все еще присутствовали при тестировании с урезанной версией, но просто не вызывались (насколько я мог видеть).

Вот пакеты:

  • [package] - общая логика
  • [package].activities - все виды деятельности и базовые виды деятельности
  • [package].database - все взаимодействие с базой данных
  • [package].models - модели для сохранения / загрузки данных
  • [package].renderables - объекты, нарисованные на холсте

Я попытался добавить в манифест атрибут `android: sharedUserId ', и он, казалось, ничего не делал при обеих попытках. Когда я вначале исследовал это, я пришел к выводу, что общий идентификатор пользователя применяется только к разным проектам, а не к разным пакетам.

Кроме того, я не верю, что когда-либо все урезали, было какое-то взаимодействие с базой данных. Тот факт, что 3-й вид деятельности может быть любым видом деятельности, даже HomeActivity, противоречит этой теории.

Полезные ссылки

Обновление 1/11 / 2012

В последние пару дней я вернулся к этому проекту, я создал совершенно новый проект в Eclipse Juno (раньше был на Helios) и перенес все вручную, чтобы инструменты Eclipse и Android обрабатывали почти все взаимодействия с Manifest, но это все еще происходит. Я посмотрю на это немного больше в течение следующих нескольких дней и обновлю, если найду что-нибудь.

К вашему сведению, мой новый проект нацелен на следующее:

<uses-sdk
    android:minSdkVersion="14"
    android:targetSdkVersion="15" />

В новой структуре проекта теперь также есть все действия в корневом пакете (т. Е. [Пакет], а не [пакет] .activities). Я также использую (новый?) Синтаксис для отображения родительской активности:

<meta-data
    android:name="android.support.PARENT_ACTIVITY"
    android:value="[my package].LoadDiagramActivity" />

Это также все еще происходит на моем теперь обновленном Galaxy Nexus под управлением Jellybean 4.1.2.

Ответы [ 9 ]

9 голосов
/ 06 апреля 2012

Попробуйте добавить еще одну вещь в файл манифеста, я уверен, что вы уже пробовали ..

<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="[my package]" 
    android:versionCode="1" 
    android:versionName="1.0"
    android:sharedUserId="com.mj.app" > 

Кажется, что в вашем проекте у вас есть несколько ПАКЕТОВ, как com.package.p1 , com.package.p2 ,com.package.p3 ..

И при запуске вы находитесь в p1, а затем переходите к p2 - p3 ... и в это время вы пытаетесь запустить его снова ... так что Android выдает ошибку.

2 голосов
/ 05 ноября 2012

Если я не ошибаюсь, это происходит только тогда, когда мы переустанавливаем приложение из Eclipse Run-> As. Так что это вряд ли произойдет, когда пользователь обновляется через Play. Я могу сказать это с уверенностью, поскольку я тоже заметил мое приложение с этим исключением во время переустановки через Eclipse, но ничего о Crittercism.

Чтобы исправить это, я работал над разрешением потребления памяти моим приложением.

  1. Если у вас есть только 1 набор раскладок, измените его Создайте drawables-mdpi и скопируйте все файлы из этой 1 папки drawables (drawables, drawable-ldpi). Если у вас есть только 1 комплект, Android изменит его размер для использования на больших экранах, тем самым внутренне занимая слишком много памяти, и очистка этого вида памяти (растровое изображение) подвержена ошибкам. Звучит безумно, но творит чудеса. Не верьте мне, запустите его под наблюдением использования кучи памяти до и после этого изменения, вы заметите, что ваше приложение использует на 25% меньше памяти для обычного сценария.
  2. Если вы выполняете какие-либо битовые операции, вы можете рассмотреть возможность уменьшения масштаба. По крайней мере, когда вы устанавливаете параметры, вы определенно хотите уменьшить его. Отметьте здесь и здесь . Поиск или уменьшение.
  3. Наконец, не забудьте bitmap.recycle(); bitmap = null; в вашем onDestroy и перед всеми System.exit (0).

Android выполняет большую часть фоновой работы, а переустановка - неожиданное ожидание очистки от приложения. Не очищенная память может вызвать проблемы. Это исключение является одним из тех internal. Так что не думайте, что это будет просто.

2 голосов
/ 04 апреля 2012

Если вы введете 13 в minSdkVersion, оно должно работать.

Либо так, либо вам нужно setDisplayHomeAsUpEnabled(false) в onCreate() вашей другой деятельности.

Оба эти решения должны работать.

Начиная с уровня API 14 согласно документации , setHomeButtonEnabled(true) больше не выполняется для вас по умолчанию, и далее говорится, что

Установка опции отображения DISPLAY_HOME_AS_UP автоматически активирует кнопку «Домой».

Таким образом, мы можем сделать вывод, что setDisplayHomeAsUpEnabled(false) работает аналогично setHomeButtonEnabled(false)

0 голосов
/ 06 января 2017

Для этого обязательно отметьте «Автоматически строить» при очистке проекта.(Проект -> Автоматическая сборка)

0 голосов
/ 07 ноября 2012

Нет ничего плохого в коде, который вы нам дали. Я только что попробовал это в новом проекте с именем пакета com.test, и он работал безупречно. Единственное, что я добавил в файлы, было объявление пакета. (И я добавил load_diagram_menu.xml, конечно.)

Если возможно, было бы здорово, если бы вы могли предоставить нам доступ ко всему проекту. Если проект работает на чужом компьютере, то, скорее всего, он плохо работает в Eclipse или в плагине Android Eclipse. Чистая установка Eclipse решит эту проблему. (Хотя я понимаю, как это может быть сложно в автономном режиме. :-))

0 голосов
/ 06 ноября 2012

Вам нужно добавить "." перед именем activity в Menifest.

Как это

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

<uses-sdk android:minSdkVersion="14" />

<application 
    android:icon="@drawable/ic_launcher" 
    android:label="@string/app_name" >
    <activity 
        android:name=".HomeActivity" 
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
    <activity android:name=".LoadDiagramActivity" android:label="Load Diagram"></activity>
    <activity android:name=".BaseDiagramActivity" android:label="Base Diagram"></activity>
</application>

Я обновляю активность вашего манифеста. Пожалуйста, проверьте это ...

0 голосов
/ 06 ноября 2012

Проверяя ваш код, я чувствую, что вы пропускаете установку "setContentView(rid)" в LoadDiagramActivity.Пожалуйста, попробуйте установить вид в onCreate().

Надеюсь, это поможет вам.

0 голосов
/ 06 ноября 2012

Подождите, пока ваше приложение не выйдет из строя, когда вы запустите его во второй раз.Приложение запустится после сбоя снова.Это случается иногда со мной.Если то же самое в случае с u, не забывайте каждый раз очищать свой проект, прежде чем запускать его.

0 голосов
/ 03 апреля 2012

Вы не добавили точку в имена своих действий в атрибутах манифеста android:name. Возможно, это вызывает проблему.

...