【Android】Service
文章目录
- 1.service
- 2.startService
- 3.bindService
- 4.区别
1.service
在Android开发中,Service 是一个可以在后台长时间运行的组件,用于执行耗时操作或执行那些不需要与用户界面直接交互的任务。Service 不依赖于用户界面,即使用户切换到其他应用,Service 仍然可以继续运行。
Service 的主要用途
- 后台任务:执行耗时操作,如下载文件、播放音乐等。
- 跨进程通信:通过 AIDL 实现跨进程通信(IPC)。
- 定时任务:定期执行某些任务,如定时同步数据。
- 保持连接:维持与服务器的长连接,如实时聊天应用。
Service生命周期

- onCreate():当 Service 第一次被创建时调用。
- onStartCommand(Intent intent, int flags, int startId):每当通过 startService() 方法启动 Service 时调用。
- onBind(Intent intent):每当通过 bindService() 方法绑定到 Service 时调用。
- onUnbind(Intent intent):当所有客户端都解除绑定时调用。
- onDestroy():当 Service 被销毁时调用。
2.startService
循环打印日志Service:
public class MyService extends Service {private static final String TAG = "ning";private ExecutorService executorService;@Overridepublic void onCreate() {super.onCreate();Log.d(TAG, "MyService onCreate");// 创建一个单线程的ExecutorServiceexecutorService = Executors.newSingleThreadExecutor();}@Overridepublic int onStartCommand(Intent intent, int flags, int startId) {Log.d(TAG, "MyService onStartCommand");// 提交一个任务到线程池,周期性地打印日志executorService.submit(() -> {while (true) {Log.d(TAG, "MyService logging at " + System.currentTimeMillis());try {Thread.sleep(1000); // 每秒打印一次日志} catch (InterruptedException e) {e.printStackTrace();}}});return START_STICKY; // 服务被系统杀死后自动重启}@Overridepublic void onDestroy() {super.onDestroy();Log.d(TAG, "MyService onDestroy");// 关闭线程池if (executorService != null) {executorService.shutdownNow();}}@Nullable@Overridepublic IBinder onBind(Intent intent) {Log.d(TAG, "MyService onBind");return null;}
}

3.bindService
public class ServiceBindActivity extends AppCompatActivity {private Button btn_bind;private Button btn_cancel;private Button btn_status;private static final String TAG = "ning";private MyBindService myBindService;private boolean isBound = false;private ServiceConnection connection = new ServiceConnection() {@Overridepublic void onServiceConnected(ComponentName name, IBinder service) {Log.d(TAG, "onServiceConnected");MyBindService.LocalBinder binder = (MyBindService.LocalBinder) service;myBindService = binder.getService();isBound = true;// 调用 Service 的方法myBindService.doSomething();}@Overridepublic void onServiceDisconnected(ComponentName name) {Log.d(TAG, "onServiceDisconnected");isBound = false;}};@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_service_bind);btn_bind = findViewById(R.id.btn_bind);btn_cancel = findViewById(R.id.btn_cancel);btn_status = findViewById(R.id.btn_status);Intent intent = new Intent(this, MyBindService.class);btn_bind.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {// 绑定 ServicebindService(intent, connection, Context.BIND_AUTO_CREATE);}});btn_cancel.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {// 解绑 ServiceunbindService(connection);}});btn_status.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {// 获取 Service 状态Log.d(TAG, "Service status: " + (myBindService == null ? "null" : "not null"));}});}@Overrideprotected void onDestroy() {super.onDestroy();// 解绑 Serviceif (isBound) {unbindService(connection);isBound = false;}}
}
public class MyBindService extends Service {private static final String TAG = "ning";private final IBinder binder = new LocalBinder();public class LocalBinder extends Binder {MyBindService getService() {return MyBindService.this;}}@Overridepublic void onCreate() {super.onCreate();Log.d(TAG, "MyBoundService onCreate");}@Overridepublic IBinder onBind(Intent intent) {Log.d(TAG, "MyBoundService onBind");return binder;}@Overridepublic boolean onUnbind(Intent intent) {Log.d(TAG, "MyBoundService onUnbind");return super.onUnbind(intent);}@Overridepublic void onDestroy() {super.onDestroy();Log.d(TAG, "MyBoundService onDestroy");}public void doSomething() {Log.d(TAG, "MyBoundService doSomething called");}
}
4.区别
在 Android 中,startService 和 bindService 都是用来启动和管理 Service 的方法,但它们的使用场景和行为有所不同。下面是它们的主要区别和使用场景:
startService
功能
- 启动型
Service:通过startService方法启动的Service是启动型Service,主要用于执行一次性的后台任务,如下载文件、上传数据等。 - 生命周期:
Service会一直运行,直到它自己调用stopSelf方法或者外部调用stopService方法将其停止。 - 回调方法:主要使用
onStartCommand方法来处理启动请求。
使用场景
- 后台任务:执行耗时操作,如下载文件、上传数据、处理大量数据等。
- 定时任务:定期执行某些任务,如定时同步数据。
- 无需与
Service交互:不需要与Service进行持续的通信,只需要启动Service并让它完成任务。
示例代码
// 启动 Service
Intent intent = new Intent(this, MyStartedService.class);
startService(intent);// 停止 Service
stopService(intent);
bindService
功能
- 绑定型
Service:通过bindService方法启动的Service是绑定型Service,主要用于组件之间的交互,如Activity与Service之间的数据交换。 - 生命周期:
Service会一直运行,直到所有绑定的客户端都解除绑定。当最后一个客户端解除绑定时,Service会调用onUnbind方法,并最终调用onDestroy方法。 - 回调方法:主要使用
onBind方法来返回一个IBinder对象,用于客户端与Service之间的通信。
使用场景
- 持续交互:需要与
Service进行持续的通信,如播放音乐、实时数据更新等。 - 跨进程通信:通过
AIDL实现跨进程通信。 - 资源共享:多个组件共享同一个
Service的资源。
示例代码
// 定义 ServiceConnection
private ServiceConnection connection = new ServiceConnection() {@Overridepublic void onServiceConnected(ComponentName name, IBinder service) {Log.d("TAG", "onServiceConnected");LocalBinder binder = (LocalBinder) service;myBoundService = binder.getService();isBound = true;// 调用 Service 的方法myBoundService.doSomething();}@Overridepublic void onServiceDisconnected(ComponentName name) {Log.d("TAG", "onServiceDisconnected");isBound = false;}
};// 绑定 Service
Intent intent = new Intent(this, MyBoundService.class);
bindService(intent, connection, Context.BIND_AUTO_CREATE);// 解绑 Service
if (isBound) {unbindService(connection);isBound = false;
}
总结
-
startService:- 用于启动一次性的后台任务。
Service会一直运行,直到显式停止。- 主要使用
onStartCommand方法处理任务。 - 适用于不需要与
Service进行持续通信的场景。
-
bindService:- 用于组件之间的持续交互。
Service的生命周期与绑定的客户端相关,当所有客户端解除绑定时,Service会停止。- 主要使用
onBind方法返回IBinder对象进行通信。 - 适用于需要与
Service进行持续通信的场景。
相关文章:
【Android】Service
文章目录 1.service2.startService3.bindService4.区别 1.service 在Android开发中,Service 是一个可以在后台长时间运行的组件,用于执行耗时操作或执行那些不需要与用户界面直接交互的任务。Service 不依赖于用户界面,即使用户切换到其他应…...
2-142【软件无线电原理与应用作业】基于matlab的圆形阵列的波束形成进行仿真
【软件无线电原理与应用作业】基于matlab的圆形阵列的波束形成进行仿真,具有14页文档。假设发射信号载频为1GHz,圆形阵列半径为0.8米,在圆周上均匀布置30个阵元。1.画出指向0度的方向图。2.如果目标在0度,有一不相干的干扰信号在3…...
在目录中按扩展名分类文件(python学习)(11.1)
# -*- coding:utf-8 -*- # FileName :SortBySuffix.py # Time :2024/11/1 15:13 # Author :liyiwei# Python脚本按扩展名在目录中对文件进行排序 import os from shutil import movedef sort_files(directory_path):# 遍历指定目录下的所有文件和文件夹for filename i…...
【网络安全 | 漏洞挖掘】逻辑漏洞+无限制爆破实现业务瘫痪
未经许可,不得转载。 文章目录 前言正文前言 目标:target.com,是一个为设计团队服务的工作平台。 该程序允许用户创建账户并组建团队,指定的领导者担任管理员。团队类型包括: 1、免费团队:限于一个项目,最多三份文件。 2、学生团队:项目和文件无限制,学生可免费获…...
【WRF工具】MPAS(多尺度预测模型)-输出WRF初始和横向边界条件
【WRF工具】MPAS(多尺度预测模型)-输出WRF初始和横向边界条件 MPAS概述模型概述主要特点 使用MPAS输出WRF初始和横向边界条件参考 从WPS的v3.9版本开始,metgrid.exe程序能够从 跨尺度预测模型(The Model for Prediction Across Sc…...
分数阶傅里叶变换与信息熵怎么用于信号处理?
天马行空的理解与思考方式:分数阶傅里叶变换与信息熵怎么用于信号处理? ChiX-Y 快速学习,快速尝试,快速失败 已关注 35 人赞同了该文章 这篇文章希望能写的有趣,同时有质量,学习就是要多维度多角度&…...
web3.0 开发实践
优质博文:IT-BLOG-CN 一、简介 Web3.0也称为去中心化网络,是对互联网未来演进的一种概念性描述。它代表着对现有互联网的下一代版本的设想和期望。Web3.0的目标是通过整合区块链技术、分布式系统和加密技术等新兴技术,构建一个更加去中心化…...
【华为HCIP实战课程三十】中间到中间系统协议IS-IS路由渗透及TAG标识详解,网络工程师
一、路由泄露 1、默认情况Level 1不会学到Level2的明细路由,L2可以学到L1的明细路由 2、FIB数据转发,路由负载,通过随机数据中的五元组hash,hash值决定数据走哪条链路 R1设备ping和telnet通过抓包查看走的都是S1/0/0接口 抓包进行过滤;ip.a…...
大模型论文精华-20241104
工具而不是对等:框架如何影响人们对 Teams 中 AI 代理的看法 研究问题 随着人工智能技术的发展及其在团队环境中日益广泛的应用,人们对于如何理解和评价AI代理的态度和看法变得尤为重要。该研究关注于探讨不同框架下人们对AI代理的感知差异,…...
mac ssh 连接 linux 服务器
生成 SSH 密钥对 打开终端: 你可以通过 Spotlight 搜索 “Terminal” 打开终端。 生成密钥对: ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 手动复制公钥(可选) 如果 ssh-copy-id 命令不可用࿰…...
逻辑卷建立
逻辑卷 lvm逻辑卷即为:logical volume manager逻辑管理卷,是linux系统下管理硬盘分区的一种机制,lvm适合于管理大型存储文件,用户可以动态的对磁盘进行扩容 作用 lvm:linux系统的一个重要的存储技术 不同的硬盘的不…...
算法深度剖析:前缀和
文章目录 前言一、一维前缀和模板二、二维前缀和模板三、寻找数组的中心下标四、除自身以外数组的乘积五、和为 K 的子数组六、和可被 K 整除的子数组七、连续数组八、矩阵区域和 前言 本章将深度剖析前缀和,以及总结前缀和模板。 前缀和是一种在算法和数据处理中…...
【双目视觉标定】——1原理与实践
0 前言 双目视觉定位是目前机器(机器人)等领域中使用得非常广泛的视觉定位技术,双目视觉是模拟人的视觉系统利用两个不同位置的摄像头的视差来确定物体的位置。由于有需要采集两个摄像头的图像共同参与计算,所以双目相机装配要求…...
Java学习笔记(十二)
Mysql explain Extra MySQL的EXPLAIN语句是优化数据库查询的重要手段,其中的Extra列包含了不适合在其他列中显示但十分重要的额外信息。以下是对Extra列的详细介绍及举例: 一、Using filesort 解释:表示MySQL会对数据使用一个外部的索引排序…...
《Java 实现希尔排序:原理剖析与代码详解》
目录 一、引言 二、希尔排序原理 三、代码分析 1. 代码整体结构 2. main方法 3. sort方法(希尔排序核心逻辑) 四、测试结果 一、引言 在排序算法的大家族中,希尔排序是一种改进的插入排序算法,它通过将原始数据分成多个子序…...
RDMA驱动学习(二)- command queue
为了实现用户对网卡硬件的配置,查询,或者执行比如create_cq等命令,mellanox网卡提供了command queue mailbox的机制,本节将以create_cq为例看下这个过程。 command queue(后续简称cmdq)是一个4K对齐的长度…...
H2 Database IDEA 源码 DEBUG 环境搭建
H2 Database IDEA 源码 DEBUG 环境搭建 基于最新的 version-2.3.230 拉取分支。 git remote add h2 https://github.com/h2database/h2database.git git fetch h2 git checkout -b version-2.3.230 version-2.3.230使用 # 启动 java -jar h2*.jar# H2 shell 方式使用 java …...
nginx系列--(三)--http
本文主要介绍http模块accept read流程,!!!请求对应的响应直接在read流程里就会返回给用户,而不需要通过write事件,和redis一样,基本都不通过eventloop write事件来发送响应给客户端,…...
通过Wireshark抓包分析,体验HTTP请求的一次完整交互过程
目录 一、关于Wireshark 1.1、 什么是Wireshark 1.2、下载及安装 二、HTTP介绍 2.1、HTTP请求过程介绍 2.2 、TCP协议基础知识 2.2.1、概念介绍 2.2.2、TCP协议的工作原理 2.2.3、三次握手建立连接 2.3.4、四次挥手断开连接 2.3、Wireshark抓包分析过程 2.3.1、三次握…...
Requestium:Python中的Web自动化新贵
文章目录 Requestium:Python中的Web自动化新贵背景:为何选择Requestium?Requestium是什么?如何安装Requestium?简单的库函数使用方法场景应用常见Bug及解决方案总结 Requestium:Python中的Web自动化新贵 背…...
HR整理面试录像超头疼?2026年这3款提取视频文本神器,自动转写最少省4小时手动录入时间
前阵子帮做互联网公司HR的死党搭手整理春招面试录像,37场单面加8场群面,我熬了两个大夜试遍了市面上主流的5款视频转文本工具,直接给结论: 听脑AI是同类工具中最值得用的,适配HR面试整理场景的能力直接拉满࿰…...
ISO-SLAM-seq:全长 RNA代谢测序服务
ISO-SLAM-seq 技术,是 SLAM-seq 与 ISO-seq 的结合,通过研发成熟的核苷类似物 4-硫尿苷 (S4U) 代谢 RNA 标记方法和基于 Oxford Nanopore Technology 纳米孔测序平台或者 PacBio 的三代全长转录组测序方法,ISO-SLAM-seq 能检测整合到总 RNA 中…...
3D点云检测实战指南-数据准备篇(一):Nuscenes数据集解析与应用
1. Nuscenes数据集基础解析 第一次接触Nuscenes数据集时,我被它庞大的数据量和精细的标注震撼到了。这个由Motional团队打造的自动驾驶数据集,包含了1000个真实驾驶场景,每个场景持续20秒。不同于普通数据集,Nuscenes最吸引我的是…...
从Pico到Pico W:无线加持下,树莓派微控制器如何重塑物联网原型设计
1. 从有线到无线的跨越:Pico W带来的物联网革命 记得我第一次用树莓派Pico做智能温湿度计项目时,被传感器布线折腾得够呛。为了把数据传到服务器,不得不在面包板上插满杜邦线,最后成品活像只炸毛的刺猬。直到Pico W出现ÿ…...
hello-uniapp图片懒加载实现:优化应用性能与流量的完整指南
hello-uniapp图片懒加载实现:优化应用性能与流量的完整指南 【免费下载链接】hello-uniapp uni-app框架演示示例 项目地址: https://gitcode.com/gh_mirrors/he/hello-uniapp 在移动应用开发中,图片加载是影响性能和用户体验的关键因素。hello-un…...
若依(ruoyi)RuoYiApp版—页面
ruoyiApp中的页面是一个符合vue规范的文件,如果你熟悉vue,这里将非常快速上手。 1.如何新增页面 uni-app中的页面,默认保存在工程根目录下的pages目录下。 每次新建页面,均需在pages.json中配置pages列表;未在pages.js…...
考研408计算机学科专业基础综合——操作系统复习
考研408计算机学科专业基础综合 操作系统复习 核心说明:本笔记聚焦考研408操作系统高频考点、必背知识点,贴合命题规律(选择题大题并重),剔除冗余内容,突出重难点,适配冲刺复习与基础巩固&#…...
2025届学术党必备的十大AI辅助写作网站实际效果
Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 在于学术写作范畴之内,AI工具正一步一步地变成提高论文质量以及写作效率的关键辅…...
个人学习实时数据管道框架--4 数据入湖实战
4.1 环境准备 1. 安装 Java 8+ 和 Maven 3.6+ 2. 下载项目代码:git clone <项目地址> 3. 配置环境变量:JAVA_HOME, HADOOP_HOME 4.2 配置文件 核心配置文件 application.properties: # Flink 配置 flink.job.name=VehicleSOCPipeline flink.parallelism=4 flink…...
3大优势让学术翻译更安全:Zotero PDF翻译插件离线方案全解析
3大优势让学术翻译更安全:Zotero PDF翻译插件离线方案全解析 【免费下载链接】zotero-pdf-translate Translate PDF, EPub, webpage, metadata, annotations, notes to the target language. Support 20 translate services. 项目地址: https://gitcode.com/gh_mi…...
