我正在尝试做一个可以接收 Action_BOOT_COMPLETED 的基本 BroadcastReceiver。每当我在模拟器中运行它时,它似乎都不像 BroadcastReceiver 代码中的代码。
清单如下:
<uses-sdk android:minSdkVersion="8" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:name=".BootAtStartupActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver
android:name=".BootAtStartupReceiver"
android:enabled="true"
android:permission="android.permission.RECEIVE_BOOT_COMPLETED" >
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</receiver>
</application>
</manifest>
主要活动:
package com.mfcoding.android.bootatstartup;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
public class BootAtStartupActivity extends Activity {
static final String TAG = "BootAtStartupActivity";
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Log.d(TAG, "onCreate");
}
}
广播接收器:
package com.mfcoding.android.bootatstartup;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.util.Log;
public class BootAtStartupReceiver extends BroadcastReceiver {
static final String TAG = "BootAtStartupReceiver";
@Override
public void onReceive(Context context, Intent intent) {
if (intent.getAction().equals(Intent.ACTION_BOOT_COMPLETED)) {
Log.d(TAG, "*** onReceive ACTION_BOOT_COMPLETED");
}
Log.d(TAG, "*** onReceive");
}
}
在 Logcat 中,我从来没有看到 BroadcastReceiver 文件的日志打印输出。我在 Logcat 中看到的只是活动日志打印输出。有任何想法吗?我想在 Logcat 中看到 Broadcast Receiver 类的 Log 打印语句。