我有一个小应用程序,我可以在其中通过代码激活活动。那里我有一个奇怪的问题,我的应用程序在启用第二个活动后死了。
这是我的设置活动:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_settings);
Log.e(getClass().getSimpleName(), "enableing activity...");
PackageManager pm = getPackageManager();
try {
ComponentName componentName = new ComponentName(this, Lancher.class);
pm.setComponentEnabledSetting(componentName,
PackageManager.COMPONENT_ENABLED_STATE_ENABLED, 0);
} catch(Exception e) {
Log.e(getClass().getSimpleName(), "Got some trouble:", e);
} finally {
Log.e(getClass().getSimpleName(), "reached finally block");
}
Log.e(getClass().getSimpleName(), "wohoo activity is enabled");
// ...
这是我的 logcat 的一些行(我删除了不相关的输出):
I/ActivityManager(1384):开始活动: Intent { act=android.intent.action.MAIN cat=[android.intent.category.LAUNCHER] flg=0x10000000 cmp= com.example.test/.Settings } 来自 pid 6566
。 ..
E/Settings(6592):启用活动...
I/PackageManager(1384): setEnabledSetting (), pkgName= com.example.test , clsName= com.example.test.Lancher , state=1, flag=0 , pid=6592, uid=10203
...
D/WindowManagerImpl(1384): finishRemoveViewLocked, mViews[1]: com.android.internal.policy.impl.PhoneWindow$DecorView@4054d318
D/Process(1384): killProcess, pid =6592
I/ActivityManager(1384): 强制停止包com.example.test uid=10203
I/RegisterService(6601): android.intent.action.PACKAGE_REMOVED 包: com.example.test
我的清单:
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.test"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk
android:minSdkVersion="8"
android:targetSdkVersion="17" />
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name=".Settings"
android:label="@string/app_name"
android:exported="true">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
<activity
android:name=".Lancher"
android:enabled="false"
android:exported="false">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.HOME" />
</intent-filter>
</activity>
</application>
</manifest>
你知道为什么我的应用程序在 finally 块没有任何输出的情况下崩溃了吗?