我已经有这个问题近两个月了,无法解决。问题是,如果我的应用程序正在运行,并且我从Eclipse运行(重新安装)我的应用程序,则会收到一条错误消息,指示我的应用程序已崩溃“不幸的是,已停止。”。我注意到,当我从PC/Eclipse上运行它时,也会发生这种情况,我认为只有在一段时间不运行它时,它才会发生。
仅当应用程序在第三个 Activity (BaseDiagramActivity
)中处于 Activity 状态,然后我从Eclipse再次运行该应用程序时,才会发生这种情况。除了这3个 Activity 之外,我基本上删除了所有应用程序,并且它仍在发生。
我已经搜索并找到了解决该问题的方法,但是找不到任何合适的答案或适用于我的答案。
由于我正在平板电脑(4.0.3)和手机(4.0.2,在更新之前的4.0.1上运行)上运行,因此这似乎不是硬件或android版本的问题。当然,除非是 Ice Cream Sandwich 虫。
让我知道是否需要更多信息。
异常(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
这实际上与什么 Activity 无关紧要,只要启动“第三” Activity (或单击
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>
附加信息
当我简化项目以提出更简单的答案时,我将所有内容都移到了程序包的 namespace 中。在实际的项目中,有5个 namespace ,当我使用精简版本进行测试时,它们仍然存在,但只是没有被调用(据我所知)。
以下是软件包:
[package]
-通用逻辑[package].activities
-所有 Activity 和基础 Activity [package].database
-与数据库[package].models
-用于保存/加载数据的模型[package].renderables
-绘制到 Canvas 上的对象我试图在 list 中添加一个“android:sharedUserId”属性,但我两次都没有执行任何操作。当我最初对此进行调查时,我得出的结论是,共享用户ID仅适用于不同的项目,而不适用于不同的程序包。
另外,我不认为删除所有内容时也不会与数据库进行任何交互。第三 Activity 可以是任何 Activity ,甚至是HomeActivity,这一事实与该理论背道而驰。
有用的链接
更新1/11/2012
最近几天,我跳回到这个项目,我在Eclipse Juno中创建了一个全新的项目(之前在Helios上进行过),并手动转移了所有内容,因此Eclipse和Android工具可以处理几乎所有的Manifest交互,但是这种交互仍在发生。在接下来的几天中,我将对其进行更多研究,如果发现任何问题,请进行更新。
仅供引用,我的新项目的目标是:
<uses-sdk
android:minSdkVersion="14"
android:targetSdkVersion="15" />
新的项目结构现在在根包中也具有所有 Activity (即[package],而不是[package] .activities)。我还使用(new?)语法显示父级 Activity :
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="[my package].LoadDiagramActivity" />
我现在更新的运行Jellybean 4.1.2的Galaxy Nexus上也仍然出现这种情况。
最佳答案
尝试在 list 文件中再添加一件事,我确定您已经尝试过了。
<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会给您错误。