Android启动式服务

服务是与活动类似的应用组件,只不过服务没有用户界面。
使用服务可以一直在后台做某些事情,比如下载一个大文件,播放一段音乐或者监听来自服务器的一个消息。
有三种类型的服务:
1、启动式服务
启动式服务可以在后台无限期的运行,即使启动这个服务的活动已经撤销,也不会影响服务的运行。
2、绑定式服务
绑定式服务会绑定到另一个应用组件,如一个活动。
这个活动可以与绑定式服务交互,发送请求并得到结果。只要与之绑定的组件还在运行,绑定式服务就会一直运行下去。这个组件不再与之绑定时服务将会被撤销。
3、调度式服务
调度式服务是安排在某个特定的事件运行的服务。

创建一个启动式服务

要创建一个新工程,其中包含一个名为MainActivity的活动,以及一个名为DelayedMessageService的服务。只要MainActivity调用DelayedMessageService,它会等待10s,然后显示一段文本。
如图创建一个名为Joke的新工程。
在这里插入图片描述

使用IntentService类创建一个基本启动式服务

要创建启动式服务,最简单的方法式扩展IntentService类,因为它提供了你需要的大多数功能。
首先利用一个意图启动这个服务,它会在一个单独的线程中运行指定的代码。
在com.hafd.joke包中创建一个名为DelayedMessageService的Java类。

package com.hafd.joke;import android.app.IntentService;
import android.content.Intent;
import androidx.annotation.Nullable;public class DelayedMessageService extends IntentService {public DelayedMessageService() {super("DelayedMessageService");}@Overrideprotected void onHandleIntent(@Nullable Intent intent) {}
}

记录消息日志

在日志中增加消息非常有用,可以利用日志检查你的代码是否能像预期那样工作。
在Java代码中告诉Android要记录什么,应用运行时可以检查Android日志中的输出。
可以使用Android.util.Log类的以下方法记录消息日志:

		Log.v(TAG, "Verbose message"); // 记录详细信息Log.d(TAG, "Debug message"); // 记录调试信息Log.i(TAG, "Info message"); // 记录普通信息Log.w(TAG, "Warning message"); // 记录警告信息Log.e(TAG, "Error message"); // 记录错误信息

完整的DelayedMessageSeervice代码

package com.hafd.joke;import android.app.IntentService;
import android.content.Intent;
import android.util.Log;import androidx.annotation.Nullable;public class DelayedMessageService extends IntentService {public static final String EXTRA_MESSAGE = "message";public DelayedMessageService() {super("DelayedMessageService");}@Overrideprotected void onHandleIntent(@Nullable Intent intent) {synchronized (this) {try {wait(10000);} catch (InterruptedException e) {e.printStackTrace();}}String text = intent.getStringExtra(EXTRA_MESSAGE);showText(text);}private void showText(final String text){Log.v("DelayedMessageService", "The message is: " + text);}
}

在AndroidManifest.xml中声明服务

其中exported表示是否可以在其他应用中使用。

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"><applicationandroid:allowBackup="true"android:dataExtractionRules="@xml/data_extraction_rules"android:fullBackupContent="@xml/backup_rules"android:icon="@mipmap/ic_launcher"android:label="@string/app_name"android:roundIcon="@mipmap/ic_launcher_round"android:supportsRtl="true"android:theme="@style/Theme.Joke"tools:targetApi="31"><activityandroid:name=".MainActivity"android:exported="true"><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity><service android:name=".DelayedMessageService"android:exported="false"></service></application></manifest>

为activity_main.xml增加一个按钮

增加两个字符串值

    <string name="question">What is the secret of comedy?</string><string name="response">Timing!</string>

接下来更新activity_main.xml,让其显示一个按钮:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:tools="http://schemas.android.com/tools"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"android:padding="16dp"tools:context=".MainActivity"><Buttonandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="center_horizontal"android:text="@string/question"android:id="@+id/button"android:onClick="onCLick"/></LinearLayout>

MainActivity使用startService启动服务

只要用户单击按钮,就要使用MainActivity的onClick方法启动DelayedeMessageService。从活动启动另一个服务与启动一个活动很类似。先要创建一个显示意图,指定你想要启动的服务。然后使用活动中的startService方法启动这个服务。

package com.hafd.joke;import androidx.appcompat.app.AppCompatActivity;import android.content.Intent;
import android.os.Bundle;
import android.view.View;public class MainActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);}public void onClick(View view){Intent intent = new Intent(this, DelayedMessageService.class);intent.putExtra(DelayedMessageService.EXTRA_MESSAGE, getResources().getString(R.string.response));startService(intent);}
}

试一试应用

在这里插入图片描述
按下按钮等待10s后切换回AS的logcat页面,会发现如下打印:

2023-10-09 09:42:46.602  8237-8306  DelayedMessageService   com.hafd.joke                        V  The message is: Timing!

启动式服务生命周期

在Android中,启动式服务的生命周期可以包括以下四个步骤:
onCreate(): 当服务第一次被创建时执行。这个方法可以在服务创建时进行一些初始化操作。
onStartCommand(): 当服务被启动的时候执行。使用startService()这个方法开启服务,但注意,如果服务已经启动过,那么onCreate()方法不会再被调用。此时服务开始执行,可以长期在后台运行。
onHandleIntent():要把希望服务在后台运行的所有代码增加到onHandleIntent()。
onDestroy(): 当服务不再被使用或被销毁时执行。
一般来说,启动式服务的生命周期就是从onCreate()到onDestroy()。不过需要注意的是,如果启动式服务没有被明确停止,那么它可能会在后台持续运行,即使用户退出了应用或设备重新启动,除非服务被系统销毁或明确停止。

Android内置通知服务

我们要修改Joke应用,在一个通知中显示消息。通知时在应用用户界面之外显示消息。发出一个通知时,它会在状态栏的通知区中显示一个图标。可以在通知抽屉中看到这个通知的详细信息,从屏幕上向下滑动就可以看到通知抽屉:

创建一个通知生成器

首先要做的是创建一个通知生成器。它允许你构建有特定内容和特性的通知。
你创建的每个通知都应当包括一个小图标、一个标题和最简版的一些文本。下面是相应的代码:

NotificationCompat.Builder builder = new NotificationCompat.Builder(this).setSmallIcon(android.R.drawable.sym_def_app_icon) //设置显示小图标.setContentTitle(getString(R.string.question)) //设置标题.setContentText(text) //设置文本.setPriority(NotificationCompat.PRIORITY_HIGH) //设置高优先级.setVibrate(new long[] {0, 1000}) //等待0ms,并震动1000ms.setAutoCancel(true);//用户单击通知时通知会消失

增加一个动作告诉通知单击时要启动哪个活动

        //启动MainActivity的普通意图Intent actionIintent = new Intent(this, MainActivity.class);PendingIntent actionPendingIntent = PendingIntent.getActivity(this, //上下文,这里是当前服务0,//不需要访问挂起意图时,可以将其设置为0actionIintent,//这是上面创建的意图PendingIntent.FLAG_UPDATE_CURRENT);//如果有一个匹配的挂起意图,它会更新//这会把这个挂起意图增加到通知builder.setContentIntent(actionPendingIntent);

使用内置通知服务发出通知

        //允许你访问Android的通知服务NotificationManager notificationManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);//使用通知服务来显示我们创建的通知notificationManager.notify(NOTIFICATION_ID, builder.build());

完整的DelayedMessageService.java

package com.hafd.joke;import android.app.IntentService;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Intent;
import android.util.Log;import androidx.annotation.Nullable;
import androidx.core.app.NotificationCompat;public class DelayedMessageService extends IntentService {public static final String EXTRA_MESSAGE = "message";public static final int NOTIFICATION_ID = 5453;public DelayedMessageService() {super("DelayedMessageService");}@Overrideprotected void onHandleIntent(@Nullable Intent intent) {synchronized (this) {try {wait(10000);} catch (InterruptedException e) {e.printStackTrace();}}String text = intent.getStringExtra(EXTRA_MESSAGE);showText(text);}private void showText(final String text){NotificationCompat.Builder builder = new NotificationCompat.Builder(this).setSmallIcon(android.R.drawable.sym_def_app_icon) //设置显示小图标.setContentTitle(getString(R.string.question)) //设置标题.setContentText(text) //设置文本.setPriority(NotificationCompat.PRIORITY_HIGH) //设置高优先级.setVibrate(new long[] {0, 1000}) //等待0ms,并震动1000ms.setAutoCancel(true);//用户单击通知时通知会消失//启动MainActivity的普通意图Intent actionIintent = new Intent(this, MainActivity.class);PendingIntent actionPendingIntent = PendingIntent.getActivity(this, //上下文,这里是当前服务0,//不需要访问挂起意图时,可以将其设置为0actionIintent,//这是上面创建的意图PendingIntent.FLAG_UPDATE_CURRENT);//如果有一个匹配的挂起意图,它会更新//这会把这个挂起意图增加到通知builder.setContentIntent(actionPendingIntent);//允许你访问Android的通知服务NotificationManager notificationManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);//使用通知服务来显示我们创建的通知notificationManager.notify(NOTIFICATION_ID, builder.build());}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/128493.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

redis中高并发问题

高并发问题 Redis 做缓存虽减轻了 DBMS 的压力&#xff0c;减小了 RT&#xff0c;但在高并发情况下也是可能会出现各 种问题的。 1 缓存穿透 当用户访问的数据既不在缓存也不在数据库中时&#xff0c;就会导致每个用户查询都会“穿透” 缓存“直抵”数据库。这种情况就称为缓…

逻辑回归评分卡

文章目录 一、基础知识点(1)逻辑回归表达式(2)sigmoid函数的导数损失函数(Cross-entropy, 交叉熵损失函数)交叉熵求导准确率计算评估指标 二、导入库和数据集导入库读取数据 三、分析与训练四、模型评价ROC曲线KS值再做特征筛选生成报告 五、行为评分卡模型表现总结 一、基础知…

10.selenium进阶

上述我们学习了selenium入门的一些操作, 本节知识点学习一些selenium的高级用法 1、嵌套网页 ​ 在前端开发中如果有这么一个需求。一个页面上的内容要被其它页面所共用。也就是说两个或者两个以上的页面需要共同存在与同一个页面。在前端页面开发中可以把写好的代码在每个页面…

Java编程技巧:Excel导入、导出(支持EasyExcel和EasyPoi)

目录 1、EasyExcel&#xff1a;普通导出2、EasyExcel&#xff1a;普通导入3、EasyExcel&#xff1a;复杂导出4、EasyPoi&#xff1a;普通导出5、EasyPoi&#xff1a;普通导入6、EasyPoi&#xff1a;复杂导出7、EasyPoi&#xff1a;复杂导入8、代码 1、EasyExcel&#xff1a;普通…

软件测试面试之问——角色扮演

作为软件测试工程师&#xff0c;在求职面试中经常会被问到这样一个问题&#xff1a;你认为测试工程师在企业中扮演着什么样的角色呢&#xff1f; 某度百科是这样概括的&#xff1a;“软件测试工程师在一家软件企业中担当的是‘质量管理’角色&#xff0c;及时发现软件问题并及…

FPGA project : fifo_sum

实验目标&#xff1a; col(列) 4 &#xff1b;line(行) 5。相邻三行&#xff0c;按列求和。输出新的数据流。 实现方法&#xff1a; 通过rs232通信协议&#xff0c;输入数据流。第一行存进fifo1&#xff0c;第二行存进fifo2.当输入第三行第一个数据的时候&#xff0c;从fif…

ChromeDriver驱动最新版下载

下载地址ChromeDriver - WebDriver for Chrome - Downloads selenium.common.exceptions.SessionNotCreatedException: Message: session not created: This version of ChromeDriver only supports Chrome version 113 Current browser version is 117.0.5938.150 with binar…

web3.0时代分布式网络协议的异同

Web3.0时代标志着分布式网络协议的兴起&#xff0c;其中IPFS&#xff08;InterPlanetary File System&#xff09;和NDN&#xff08;Named Data Networking&#xff09;是备受瞩目的项目。尽管它们都属于分布式网络协议领域&#xff0c;但在多个方面存在显著区别。以下是IPFS和…

端粒/端粒酶生信切入点,6+端粒酶+泛癌+甲基化+实验。

今天给同学们分享一篇端粒酶泛癌甲基化实验的生信文章“Genomic, epigenomic, and transcriptomic signatures for telomerase complex components: a pan‐cancer analysis”&#xff0c;这篇文章于2022年10月31日发表在Mol Oncol期刊上&#xff0c;影响因子为6.6。 激活端粒酶…

New Journal of Physics:不同机器学习力场特征的准确性测试

文章信息 作者&#xff1a;Ting Han1, Jie Li1, Liping Liu2, Fengyu Li1, * and Lin-Wang Wang2, * 通信单位&#xff1a;内蒙古大学物理科学与技术学院、中国科学院半导体研究所 DOI&#xff1a;10.1088/1367-2630/acf2bb 研究背景 近年来&#xff0c;基于DFT数据的机器学…

一款构建Python命令行应用的开源库

1 简介 当我们编写 Python 程序时&#xff0c;我们经常需要与用户进行交互&#xff0c;接收输入并输出结果。Python 提供了许多方法来实现这一点&#xff0c;其中一个非常方便的方法是使用 typer 库。typer 是一个用于构建命令行应用程序的 Python 库&#xff0c;它使得创建命令…

小红书婴童产业探索,解析消费者需求!

在消费升级、市场引导的背景下&#xff0c;众多产业都在悄然发生着变化&#xff0c;其中“婴童产业”就是非常有代表性的一个。今天就来深入分析小红书婴童产业探索&#xff0c;解析消费者需求&#xff01; 一、何为婴童产业 事实上&#xff0c;婴童产业&#xff0c;并不仅仅局…