Exceção quando executo meu aplicativo no Eclipse

Estou com esse problema há quase 2 meses e não consigo descobrir. O problema é que, se meu aplicativo está em execução e eu executo (reinstale) meu aplicativo no Eclipse, recebo uma mensagem de erro indicando que meu aplicativo travou 'Infelizmente, parou.'. Percebo que isso também ocorre quando o corro para longe do meu PC / Eclipse. Acho que isso acontece apenas depois que eu não o corro por um temp

Ocorre apenas se o aplicativo estiver ativo na 3ª atividade BaseDiagramActivity) e, em seguida, executo o aplicativo novamente no Eclipse. Eu tirei basicamente todo o aplicativo, exceto as três atividades e ainda está acontecend

Procurei e procurei uma solução para esse problema, mas não consigo encontrar nenhuma resposta boa ou que se aplique a mim.

Não parece um problema de versão do hardware ou do Android, pois estou executando isso no meu tablet (4.0.3) e no meu telefone (4.0.2, estava acontecendo no 4.0.1 antes da atualização). A menos, é claro, que seja um bug do sanduíche de sorvet

Deixe-me saber se mais alguma informação é necessári

A exceção (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
O Código Android

LoadedApk.initializeJavaContextClassLoader () - A linha 362 parece ser o ofensor

Abaixo estão os arquivos relevantes:

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

, na verdade, não importa qual é a atividade, a exceção ocorre desde que uma 'terceira' atividade seja iniciada (ou clicando no botão Adicionar emLoadDiagramActivity.

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>
Informação adiciona

Quando reduzi meu projeto para pedir uma resposta mais simples, mudei tudo para o espaço de nome do pacote. No projeto real, existem 5 namespaces, eles ainda estavam presentes quando eu estava testando com a versão simplificada, mas simplesmente não foi chamada (tanto quanto pude ver

Aqui estão os pacotes:

[package] - lógica geral[package].activities - todas as atividades e atividades básicas[package].database - toda interação com o banco de dados[package].models - modelos para salvar / carregar dados[package].renderables - objetos desenhados em uma tela

Tentei adicionar um atributo `android: sharedUserId 'ao manifesto e ele parecia não fazer nada nas duas vezes que tentei. Quando eu estava investigando isso inicialmente, cheguei à conclusão de que o ID do usuário compartilhado só se aplicava a projetos diferentes, e não a pacotes diferente

Também não acredito que tenha havido interação com o banco de dados quando eu retirei tudo. O fato de a terceira atividade poder ser qualquer atividade, até HomeActivity, foi algo contra essa teori

Links Úteistackoverflow: android.app.Application não pode ser instanciado devido a NullPointerExceptionGreoCode android.app.LoadedApk em 4.0.1 Condição de corrida possível?Android issue # 25869Update 11/11/2012

Um par de dias em que voltei a este projeto, criei um novo projeto no Eclipse Juno (já estava no Helios) e transferi tudo manualmente, para que as ferramentas do Eclipse e Android lidassem com quase toda a interação do Manifest, mas ainda é ocorrendo. Vou analisá-lo um pouco mais nos próximos dias e atualizar se encontrar alguma coisa.

FYI meu novo projeto tem como alvo o seguinte:

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

A nova estrutura do projeto também possui todas as atividades no pacote raiz agora (por exemplo, [pacote], não [pacote]. Atividades). Também estou usando a sintaxe (nova?) Para mostrar a atividade pai:

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

Também ainda está ocorrendo no meu Galaxy Nexus, agora atualizado, executando o Jellybean 4.1.

questionAnswers(18)

yourAnswerToTheQuestion