报错信息如下:

09-30 21:33:44.932    4531-4531/com.example.raid.bindservice E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: com.example.raid.bindservice, PID: 4531
java.lang.IllegalArgumentException: Service Intent must be explicit: Intent { act=com.example.raid.service.FIRST_SERVICE }
at android.app.ContextImpl.validateServiceIntent(ContextImpl.java:1688)
at android.app.ContextImpl.startServiceCommon(ContextImpl.java:1717)
at android.app.ContextImpl.startService(ContextImpl.java:1701)
at android.content.ContextWrapper.startService(ContextWrapper.java:516)
at com.example.raid.bindservice.MainActivity$1.onClick(MainActivity.java:29)
at android.view.View.performClick(View.java:4780)
at android.view.View$PerformClick.run(View.java:19866)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5254)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698)

报错原因:

因为版本的原因,有些时候我们使用Service的时需要采用隐私启动的方式,但是Android 5.0一出来后,其中有个特性就是Service Intent  must be explitict,也就是说从Lollipop开始,service服务必须采用显示方式启动。

5.0前的版本只需要如下代码即可开启服务:

final Intent intent = new Intent();
intent.setAction("com.example.raid.service.FIRST_SERVICE");

但是现在需要加上一个setPackage方法:

final Intent intent = new Intent();
intent.setAction("com.example.raid.service.FIRST_SERVICE");
intent.setPackage(getPackageName());