Android 服务(Service)适合执行那些不需要和用户交互而且还要求长期运行的任务。
服务的运行不依赖于任何用户界面,即使 APP 被切换到后台,或者打开了另外一个 APP,服务仍然能够保持正常运行。
但是当某个 APP 进程被杀掉时,那么这个 APP 所创建的所有服务也就停止咯。
另外,服务本身并不会自动开启线程,服务代码默认是运行在主线程中的。所以如果需要执行的业务逻辑耗时长,那么为了防止主线程被阻塞,我们必须在服务内部创建子线程来执行这些业务逻辑。
1 定义服务
在 Android Studio 中可以通过 File→New→Service→Service 来创建服务:
在弹出的对话框中配置服务:
在此配置服务名。下面两个配置项说明如下:
* Exported:是否允许除了当前程序之外的其他程序访问这个服务。(默认勾选)
* Enabled:是否启用这个服务 。 (默认勾选)
public class FirstService extends Service { private static final String TAG = "FirstService"; @Override public void onCreate() { super.onCreate(); Log.d(TAG, "onCreate"); } @Override public int onStartCommand(Intent intent, int flags, int startId) { Log.d(TAG, "onStartCommand"); return super.onStartCommand(intent, flags, startId); } @Override public void onDestroy() { super.onDestroy(); Log.d(TAG, "onDestroy"); } public FirstService() { } @Override public IBinder onBind(Intent intent) { // TODO: Return the communication channel to the service. throw new UnsupportedOperationException("Not yet implemented"); } }
创建好后的服务继承自 Service,并且需要实现 onBind() 方法。我们在此还重写了以下几个方法:
方法 | 说明 |
---|---|
void onCreate() | 服务创建时调用该方法。 |
onStartCommand(Intent intent, int flags, int startId) | 每次服务启动时调用该方法。 |
void onDestroy() | 服务销毁时调用该方法。 |
我们还在这些方法中加入了日志,便于观察运行结果。
此外,在此类的任何位置调用 stopSelf() 方法,服务就会自行停止。
定义好服务后,需要在 AndroidManifest.xml 中注册服务(如果用的是 Android Studio,那么这一步它已经帮我们做啦):
<service android:name=".FirstService" android:enabled="true" android:exported="true"></service>
2 启动或停止服务
借助 Intent,我们就可以控制服务的启动与停止啦O(∩_∩)O哈哈~
final Context context = this; findViewById(R.id.start_service).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //启动服务 startService(new Intent(context, FirstService.class)); } }); findViewById(R.id.stop_service).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { //停止服务 stopService(new Intent(context, FirstService.class)); } });
这里的 startService() 和 stopService() 方法都是定义在 Context 类中,所以在活动类中可以直接调用。
执行结果:
D/FirstService: onCreate D/FirstService: onStartCommand D/FirstService: onDestroy
**注意:**onCreate() 在第一次创建服务时被调用,而 onStartCommand() 会在每次启动服务时被调用。
服务启动后,可以在 Android 的 Settings → Developer opinions → Running services 中发现它:
点击 APP 后,可以看到服务详情:
如果找不到 Developer opinions 选项,请先在 Android 的 Settings → About emulated device → 多次点击 Build number 就可以开启开发者模式啦:
3 活动控制服务
活动是通过实现 ServiceConnection 接口来与服务建立连接的,它包含以下两个方法:
方法 | 说明 |
---|---|
onServiceConnected(ComponentName name, IBinder service) | 服务绑定后调用该方法。 |
onServiceDisconnected(ComponentName name) | 服务解绑后调用该方法。 |
而服务是通过实现 IBinder onBind(Intent intent) 方法来转换为 onServiceConnected() 方法所需要的 IBinder 型的 service 参数的。
首先,我们修改服务类:
public class FirstService extends Service { class CustomBinder extends Binder { public void init(){ Log.d(TAG, "init CustomBinder"); } } @Override public IBinder onBind(Intent intent) { return new CustomBinder(); } }
这里,我们定义了一个内部类 CustomBinder,里面实现了一个简单的初始化方法。然后在 onBind() 方法中返回它的实例。
接着,我们修改活动类,创建 ServiceConnection 实例:
private ServiceConnection connection = new ServiceConnection() { @Override public void onServiceConnected(ComponentName name, IBinder service) { Log.d(TAG, "onServiceConnected"); FirstService.CustomBinder customBinder = (FirstService.CustomBinder) service; customBinder.init(); } @Override public void onServiceDisconnected(ComponentName name) { Log.d(TAG, "onServiceDisconnected"); } };
现在,就可以通过 ServiceConnection 实例来绑定或者解绑服务啦。
绑定服务:
bindService(new Intent(context, FirstService.class), connection, BIND_AUTO_CREATE);
bindService 接收三个参数:
参数 | 类型 | 说明 |
---|---|---|
service | Intent | 这个 Intent 将绑定当前的活动类与服务类。 |
conn | ServiceConnection | ServiceConnection 对象。 |
flags | int | 绑定服务的方式。这里的 BIND_AUTO_CREATE 表示绑定后自动创建服务。 |
【绑定服务】输出结果:
D/FirstService: onCreate D/MainActivity: onServiceConnected D/FirstService: init CustomBinder
解绑服务:
unbindService(connection);
只要传入 ServiceConnection 对象即可解绑,是不是很简单呀 O(∩_∩)O哈哈~
【解绑服务】输出结果:
D/FirstService: onDestroy
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍说说微服务架构的优势。相关面试题,主要包含被问及说说微服务架构的优势。时的应答技巧和注意事项,需要的朋友参考一下 优势 说明 独立开发 所有微服务都可以根据各自的功能轻松开发 独立部署 根据他们所提供的服务,可以在任何应用中单独部署 故障隔离 即使应用中的一个服务不起作用,系统仍然继续运行 混合技术栈 可以用不同的语言和技术来构建同一应用程序的不同服务 粒度缩放 各个组件可根据需要进
本文向大家介绍说说 Dubbo 服务暴露的过程。相关面试题,主要包含被问及说说 Dubbo 服务暴露的过程。时的应答技巧和注意事项,需要的朋友参考一下 Dubbo 会在 Spring 实例化完 bean 之后,在刷新容器最后一步发布 ContextRefreshEvent 事件的时候,通知实现了 ApplicationListener 的 ServiceBean 类进行回调 onApplicati
我有一个流行的大声朗读应用程序,视力障碍者和盲人也经常使用它。有些人,很少有人抱怨说,当使用应用程序或大声朗读时,它反复说“语音服务”(我的应用程序的名称是@Voice大声阅读器)。我在几部启用了不同版本的Android和TalkBack的手机上进行了测试,但无法重现此问题。 该应用程序正在显示一个阅读进度通知和暂停/恢复、快进和快退等按钮。当然,所有的朗读都是通过服务完成的,而不是活动,因为用户
本文向大家介绍Android ContentResolver使用说明,包括了Android ContentResolver使用说明的使用技巧和注意事项,需要的朋友参考一下 Android是如何实现应用程序之间数据共享的?一个应用程序可以将自己的数据完全暴露出去,外界更本看不到,也不用看到这个应用程序暴露的数据是如何存储的,或者是使用数据库还是使用文件,还是通过网上获得,这些一切都不重要,重要的是外
Android SDK 使用文档 需要许可如下权限(添加到 AndroidManifest.xml 文件中) <uses-permission android:name="android.permission.READ_PHONE_STATE"/> <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/> <use
服务面板包括 主面板、通用说明 和 插件扩展 三部分。以 Cocos Analytics 服务为例: 主面板 使用指南:前往对应服务的官方文档。 前往控制台:前往对应服务的控制后台。 Sample 工程:对应服务的 Cocos Creator Sample 工程。 版本管理:点击 版本号 即可打开版本管理面板,查看该版本说明。点击 请选择版本 可在下拉框中切换 其他历史版本。 通用说明 计费:目前