刚刚在一个服务中监听广播,接收广播后希望startActivity,结果报错。错误如下,红色部分是主要内容,其中一个关键词是FLAG_ACTIVITY_NEW_TASK。
10-01 17:08:02.412:E/AndroidRuntime(15737): FATAL EXCEPTION: main
10-01 17:08:02.412:E/AndroidRuntime(15737): java.lang.RuntimeException: Error receiving broadcastIntent { act=android.intent.action.SCREEN_ON flg=0x50000010 } incom.yulong.android.health.record.StepService$ScreenStatusReceiver@41ba3cf0
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:781)
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.os.Handler.handleCallback(Handler.java:733)
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.os.Handler.dispatchMessage(Handler.java:95)
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.os.Looper.loop(Looper.java:136)
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.app.ActivityThread.main(ActivityThread.java:5156)
10-01 17:08:02.412:E/AndroidRuntime(15737): atjava.lang.reflect.Method.invokeNative(Native Method)
10-01 17:08:02.412:E/AndroidRuntime(15737): atjava.lang.reflect.Method.invoke(Method.java:515)
10-01 17:08:02.412:E/AndroidRuntime(15737): atcom.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:818)
10-01 17:08:02.412:E/AndroidRuntime(15737): atcom.android.internal.os.ZygoteInit.main(ZygoteInit.java:634)
10-01 17:08:02.412:E/AndroidRuntime(15737): atdalvik.system.NativeStart.main(Native Method)
10-0117:08:02.412: E/AndroidRuntime(15737): Caused by:android.util.AndroidRuntimeException: Calling startActivity() from outside ofan Activity context requires the FLAG_ACTIVITY_NEW_TASK flag. Is this reallywhat you want?
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.app.ContextImpl.startActivity(ContextImpl.java:1097)
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.app.ContextImpl.startActivity(ContextImpl.java:1084)
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.content.ContextWrapper.startActivity(ContextWrapper.java:311)
……
10-01 17:08:02.412:E/AndroidRuntime(15737): atandroid.app.LoadedApk$ReceiverDispatcher$Args.run(LoadedApk.java:764)
10-01 17:08:02.412:E/AndroidRuntime(15737): ... 9more
以下是百度学习法找到的答案,验证有效。(原文链接)
=======================================
报错位置原始写法:
public void onReceive(Context context, Intent intent) {
……
Intent startTaobao = new Intent(context, Start.class);
context.startActivity(startTaobao);
……
}
发生错误原因分析:
Content的startActivity方法,需要开启一个新的task。如果使用Activity的startActivity方法,不会有任何限制,因为Activity继承自Context,重载了startActivity方法。
解决办法:
按照错误提示,添加一个FLAG_ACTIVITY_NEW_TASK Flag,代码如下。
public void onReceive(Context context, Intent intent) {
……
Intent startTaobao = new Intent(context, Start.class);
startTaobao.addFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
context.startActivity(startTaobao);
……
}