Service常见问题

1.service的start和bind的方式区别

两者生命周期不同
start方式有自己独立的生命周期,多次启动服务,只会调用一次oncreate(),但是会重复调用onstartcommand(),停止服务使用stopservice方法,不管start几次,只需要调用一次stopservice即可
Bind方式可以由绑定者调用服务里的方法,多次绑定需要多次解绑且只会调用一次onbind

2.同一个service,先采用start方式,再采用bind方式,如何销毁service

需要先解绑,然后再调用stopservice。

3.Onstartcommand方法返回值有几种,有什么区别

onStartCommand() 方法返回整型数来描述系统应该如何在服务终止的情况下继续运行服务.
返回的值必须是以下常量之一:
START_STICKY
如果服务在开始后 (onStartCommand() 返回后) 被终止, 比如内存不足, 然后会保持已开始状态 (started state), 但是并不保留接收的 intent. 稍后当系统有足够内存时会自己尝试重新创建服务. 因为服务仍处于已开始状态, 所以重建后会调用 onStartCommand() 方法. 但是除非此时有挂起的 intent 要启动服务, 不然传递的 intent 为 null. 使用此方式需要在代码中考虑处理 null 的情况.
该模式主要用于可以在任意的时间段显示的开始和结束服务, 比如后台的音乐播放服务.
START_NOT_STICKY
如果服务在开始后 (onStartCommand() 返回后) 被终止, 但是不会保持已开始状态. 系统也不会再自建该服务. 只能通过显示的调用 startService(Intent) 来重新创建服务. 这是最安全的选项, 可以避免在不必要时以及应用能够轻松重启所有未完成的作业时运行服务.
START_REDELIVER_INTENT
如果服务在开始后 (onStartCommand() 返回后) 被终止, 则会重建服务, 并且传入最后一个接收的 intent 到 onStartCommand(). 这适用于主动执行应该立即恢复的服务(例如下载文件).
小结:
START_STICKY, START_REDELIVER_INTENT: 会重启服务
START_STICKY: 会传递 null 的 intent
START_REDELIVER_INTENT: 会传递最后一个 intent

4.service生命周期方法都运行在哪个线程

service默认是运行在主线程,其生命周期方法也是运行在主线程,若是要执行耗时操作,必须另起线程,否则会产生ANR

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 【Android Service】 Service 简介(★★★) 很多情况下,一些与用户很少需要产生交互的应用程...
    Rtia阅读 8,331评论 1 21
  • 2.1 Activity 2.1.1 Activity的生命周期全面分析 典型情况下的生命周期:在用户参与的情况下...
    AndroidMaster阅读 8,292评论 0 8
  • 上篇我们讲解了Android中的5中等级的进程,分别是:前台进程、可见进程、服务进程、后台进程、空进程。系统会按照...
    徐爱卿阅读 9,296评论 6 33
  • 前言:本文所写的是博主的个人见解,如有错误或者不恰当之处,欢迎私信博主,加以改正!原文链接,demo链接 Serv...
    PassersHowe阅读 5,292评论 0 5
  • 昨天的跑步,今天才补上。 去年九月份我才开始跑步的,主要是减重。一直跑到了十一月份,然后停了下来,一个多月的时间,...
    WyattWang阅读 2,732评论 0 1

友情链接更多精彩内容