tangguo

从Eclipse运行应用程序时发生异常

android

我已经有这个问题近两个月了,无法解决。问题是,如果我的应用程序正在运行,并且我从Eclipse运行(重新安装)我的应用程序,则会收到一条错误消息,指示我的应用程序已崩溃“不幸的是,已停止。”。我注意到,当我从PC / Eclipse上运行它时,也会发生这种情况,我认为只有在一段时间不运行它时,它才会发生。

仅当应用程序在第三个活动(BaseDiagramActivity)中处于活动状态,然后我从Eclipse重新运行该应用程序时,才会发生这种情况。除了这3个活动之外,我基本上删除了所有应用程序,并且它仍在发生。

我已经搜索了该问题的解决方案,但找不到任何合适的答案或适用于我的答案。

这似乎不是硬件或Android版本的问题,因为我正在平板电脑(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”属性,但两次都没有执行任何操作。当我最初对此进行调查时,我得出的结论是,共享用户ID仅适用于不同的项目,而不适用于不同的程序包。

另外,我不认为删除所有内容时也不会与数据库进行任何交互。第三活动可以是任何活动,甚至是HomeActivity,这一事实与该理论背道而驰。


阅读 522

收藏
2020-11-09

共1个答案

小编典典

尝试在清单文件中再添加一件事,我确定您已经尝试过了。

<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" > 

看来您的专案中有多个PACKAGES,例如com.package.p1 , com.package.p2 ,com.package.p3..

在启动时,您进入其中p1,然后继续到p2 - p3… ,然后您尝试再次运行它。.因此,Android给您错误。

2020-11-09