当前位置: 首页 > news >正文

Android中Service学习记录

目录

    • 一 概述
    • 二 生命周期
      • 2.1 启动服务startService()
      • 2.2 绑定服务bindService()
      • 2.3 先启动后绑定
      • 2.4 先绑定后启动
    • 三 使用
      • 3.1 本地服务(启动式)
      • 3.2 可通信的服务(绑定式)
      • 3.3 前台服务
      • 3.4 IntentService
    • 总结
    • 参考

一 概述

Service组件一般用来执行长期在后台的任务,如播放音乐、直播、下载文件等。

二 生命周期

官方图,一图解千言
在这里插入图片描述
两种使用Service的方法,执行不同的生命周期。

2.1 启动服务startService()

调用startService方法启动,多次启动onCreate只一次,onStartCommand会多次;
需要手动停止,调用stopService方法或stopItSelf。

2.2 绑定服务bindService()

调用bindService方法绑定,一次unBindService就能结束服务;如果多次调用unBindService,会出错。
当绑定的对象销毁时,自动解绑;绑定的对象也可以调用unBindService来进行主动解绑。

2.3 先启动后绑定

onCreate -> onStartCommand -> onBind -> onUnBind -> onDestroy

2.4 先绑定后启动

onCreate -> onBind -> onStartCommand -> onUnBind -> onDestroy

三 使用

都是Compose写的,很简陋,ui部分就不贴出来了。

3.1 本地服务(启动式)

两个按钮,一个启动服务,一个停止服务。
思路:
1.继承Service重写方法
2.注册Service
3.使用启动和停止方法

部分代码:

class MyService: Service() {private val mBinder = MyBinder()override fun onCreate() {println("MyService onCreate")super.onCreate()}override fun onStartCommand(intent: Intent?, flags: Int, startId: Int): Int {println("MyService onStartCommand")return super.onStartCommand(intent, flags, startId)}override fun onBind(p0: Intent?): IBinder? {println("MyService onBind")return mBinder}override fun onUnbind(intent: Intent?): Boolean {println("MyService onUnbind")return super.onUnbind(intent)}override fun onDestroy() {println("MyService onDestroy")super.onDestroy()}class MyBinder: Binder() {fun getServiceMethod() {println("this is service method")}}}
  <service android:name=".MyService"></service>

多次点击启动,再多次点击停止后结果如下,没有问题。
在这里插入图片描述

3.2 可通信的服务(绑定式)

思路:
1.同样先继承一个服务,但是多了一个自定义内部类继承binder如MyBinder,并自定义需要的方法,在onBind方法返回的时候return MyBinder的实例
2.注册Service
3.初始化ServiceConnection 实例,并在方法里将service转成MyBinder类型,然后可以执行类的方法。
4.使用绑定和启动方法
部分代码:

val connection: ServiceConnection = object : ServiceConnection {override fun onServiceConnected(name: ComponentName?, service: IBinder?) {println("onServiceConnected")val binder = service as MyService.MyBinderbinder.getServiceMethod()}override fun onServiceDisconnected(name: ComponentName?) {println("onServiceDisconnected")}}context.bindService(intent,connection,BIND_AUTO_CREATE)context.unbindService(connection)

多次点击,和启动式不同,只会执行onBind一次,解绑只能一次,第二次就报错退出。
在这里插入图片描述

3.3 前台服务

不同之处在于通知栏会显示服务;优先级比较高,不会由于系统内存不足而被回收;而后台服务会。

部分代码

val notificationIntent = Intent(this, MainActivity::class.java)
val pendingIntent = PendingIntent.getActivity(this,0,notificationIntent,PendingIntent.FLAG_IMMUTABLE)
val builder = NotificationCompat.Builder(this, "channel_1")builder.setContentTitle("我是ServiceDemo的前台服务")builder.setContentText("今天2024.07.24提前下班")builder.setSmallIcon(R.mipmap.ic_launcher)builder.setContentIntent(pendingIntent)val notification = builder.build()startForeground(1, notification)

注意:
从Android 8.0(API 级别 26)开始,所有通知都必须通过通知渠道发送。通知渠道允许用户为不同类型的通知设置偏好,比如是否显示通知、是否播放声音、是否振动等。

从Android 13(API级别33)开始,对前台服务的管理变得更加严格,以改善用户体验和系统资源的管理。在Android 14(API级别34)中,这一要求被进一步强调。如果你的应用的targetSdkVersion设置为34或更高,那么在调用Service.startForeground()方法之前,你必须在应用的AndroidManifest.xml文件中的元素上明确指定foregroundServiceType属性。
还要配置权限和通知渠道。
bulider的配置也是缺一不可才会显示具体效果

<uses-permission android:name="android.permission.FOREGROUND_SERVICE"/><service android:name=".MyService"android:foregroundServiceType="specialUse">
</service>

效果:
在这里插入图片描述

3.4 IntentService

继承自Service,有一个工作线程来执行耗时任务;异步任务执行是按顺序的。会自动停止,不需要手动。
而传统的Service在主线程,不能执行耗时任务。

被弃用了,懒得学了;需要的时候再看看。
适用场景有离线下载任务等-。

总结

  • Service有两种使用模式
  • Service可以在后台也可以到前台
  • Service在主线程,不能执行耗时操作

参考

https://blog.csdn.net/JMW1407/article/details/122347723

http://www.lryc.cn/news/407190.html

相关文章:

  • Elasticsearch:Java ECS 日志记录 - log4j2
  • MongoDB自学笔记(四)
  • 时序分解 | Matlab基于CEEMDAN-CPO-VMD的CEEMDAN结合冠豪猪优化算法(CPO)优化VMD二次分解
  • 新版海螺影视主题模板M3.1全解密版本多功能苹果CMSv10后台自适应主题
  • 汽车免拆诊断案例 | 2014 款上汽名爵 GT 车发动机无法起动
  • vue3前端开发-小兔鲜项目-登录功能的业务接口调用
  • 【Linux】vim编辑器使用详解
  • 手机怎么设置不同的ip地址
  • SpringBoot读取配置的6种方式
  • 1.1 openCv -- 介绍
  • 探索PostgreSQL的GUI工具:提升数据库管理效率
  • 【从零开始实现stm32无刷电机FOC】【实践】【5/7 stm32 adc外设的高级用法】
  • springcloud接入seata管理分布式事务
  • Android APP 音视频(02)MediaProjection录屏与MediaCodec编码
  • java中log4j.properties配置文件浅析
  • RV1126 Linux 系统,接外设,时好时坏(二)排查问题的常用命令
  • 鸿蒙北向开发 DevEco Studio 4.1 下载安装傻瓜式教程
  • pglogical扩展的基本用法介绍
  • 2024年虚拟主机转移教程
  • Python 函数对象和函数调用
  • sql注入的专项练习 sqlilabs(含代码审计)
  • 淄博网站建设贵不贵
  • 【学习笔记】无人机系统(UAS)的连接、识别和跟踪(十)-无人机A2X服务
  • 基于迁移学习的手势分类模型训练
  • 个性化音频生成GPT-SoVits部署使用和API调用
  • MFC列表框示例
  • Android TabLayout的简单用法
  • 基于vite + pnpm monorepo 实现一个UI组件库
  • FDM3D打印系列——Luck13关节可动模型打印和各种材料的尝试
  • windows10 获取磁盘类型