コードでアクティビティをアクティブ化して遊ぶ小さなアプリがあります。そこで、2番目のアクティビティを有効にした後にアプリが停止するという奇妙な問題があります。
これが私の設定アクティビティです:
@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):アクティビティの開始:インテント{act = android.intent.action.MAIN cat = [android.intent.category.LAUNCHER] flg = 0x10000000 cmp = com.example.test / .Settings } frompid6566
。 ..
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ブロックからの出力なしでクラッシュするのか分かりますか?