安卓常见设计模式10------责任链模式(Kotlin版)
1. W1 是什么,什么是责任链模式?
- 责任链模式(Chain of Responsibility Pattern)是一种行为型设计模式,它用于将请求的发送者和接收者解耦,并将请求沿着一个处理链进行传递,直到有一个处理者能够处理该请求或者请求到达末尾。
- 责任链模式允许多个对象都有机会处理请求,而不是将请求的发送者和接收者直接耦合在一起。
2. W2 为什么,为什么需要使用责任链模式,能给我们编码带来什么好处?
-
解耦和灵活性:责任链模式将请求的发送者和接收者解耦,每个处理者只负责处理自己能够处理的请求,可以根据需要动态调整和扩展处理链。
-
可扩展性:可以方便地添加新的处理者到处理链中,不影响现有的处理者和客户端代码。
-
可维护性:责任链模式使得代码更易于理解和维护,每个处理者只关注自己的职责,使得代码结构清晰。
3. W3,如何使用?下面是代码示例:
假设有一个 Android 应用程序,用户可以通过不同的验证方式进行身份验证,包括指纹验证、面部识别和密码验证。我们可以使用责任链模式来实现这个验证过程:
// 抽象处理者
abstract class AuthenticationHandler {private var nextHandler: AuthenticationHandler? = nullfun setNext(handler: AuthenticationHandler) {nextHandler = handler}fun authenticate(request: AuthenticationRequest) {if (canHandle(request)) {handle(request)return} else if (nextHandler != null) {nextHandler?.authenticate(request)} else {println("无法验证身份")}}protected abstract fun canHandle(request: AuthenticationRequest): Booleanprotected abstract fun handle(request: AuthenticationRequest)
}// 指纹验证处理者
class FingerprintHandler : AuthenticationHandler() {override fun canHandle(request: AuthenticationRequest): Boolean {return request.method == AuthenticationMethod.FINGERPRINT}override fun handle(request: AuthenticationRequest) {println("进行指纹验证")// 进行指纹验证的具体逻辑}
}// 面部识别处理者
class FaceRecognitionHandler : AuthenticationHandler() {override fun canHandle(request: AuthenticationRequest): Boolean {return request.method == AuthenticationMethod.FACE_RECOGNITION}override fun handle(request: AuthenticationRequest) {println("进行面部识别")// 进行面部识别的具体逻辑}
}// 密码验证处理者
class PasswordHandler : AuthenticationHandler() {override fun canHandle(request: AuthenticationRequest): Boolean {return request.method == AuthenticationMethod.PASSWORD}override fun handle(request: AuthenticationRequest) {println("进行密码验证")// 进行密码验证的具体逻辑}
}// 身份验证请求
data class AuthenticationRequest(val method: AuthenticationMethod)// 身份验证方式枚举
enum class AuthenticationMethod {FINGERPRINT,FACE_RECOGNITION,PASSWORD
}// 客户端代码
fun main() {val fingerprintHandler = FingerprintHandler()val faceRecognitionHandler = FaceRecognitionHandler()val passwordHandler = PasswordHandler()// 构建处理链fingerprintHandler.setNext(faceRecognitionHandler)faceRecognitionHandler.setNext(passwordHandler)// 创建身份验证请求val request = AuthenticationRequest(AuthenticationMethod.FACE_RECOGNITION)// 发起身份验证请求fingerprintHandler.authenticate(request)
}
上面的示例中,身份验证沿着一个处理链进行传递,直到有一个处理者能够验证,则停止处理链的执行。如果需求需要走完整个处理链,否则就抛出异常的话,请参考下面的示例:
假设在一个电子商务平台上,当用户下单购买商品时,订单需要经过一系列的处理步骤,包括库存检查、价格计算、优惠券验证、支付处理等。
在这个场景下,也可以使用责任链模式来处理订单。每个处理步骤都可以看作是责任链中的一个处理者,它们按照一定的顺序链接在一起。当一个订单被创建后,它会依次经过责任链中的每个处理者,直到订单被完全处理。
interface OrderHandler {fun handleOrder(order: Order)
}class InventoryCheckHandler : OrderHandler {var nextHandler: OrderHandler? = nulloverride fun handleOrder(order: Order) {// 检查库存是否充足// 若库存不足,抛出异常或进行其他处理// 若库存充足,将订单传递给下一个处理者nextHandler?.handleOrder(order)}
}class PriceCalculationHandler : OrderHandler {var nextHandler: OrderHandler? = nulloverride fun handleOrder(order: Order) {// 计算订单的价格// 将价格计算结果存入订单对象// 将订单传递给下一个处理者nextHandler?.handleOrder(order)}
}class CouponValidationHandler : OrderHandler {var nextHandler: OrderHandler? = nulloverride fun handleOrder(order: Order) {// 验证订单中的优惠券是否有效// 若优惠券无效,抛出异常或进行其他处理// 若优惠券有效,将订单传递给下一个处理者nextHandler?.handleOrder(order)}
}class PaymentHandler : OrderHandler {override fun handleOrder(order: Order) {// 处理订单的支付操作// 更新订单状态等// 完成订单处理,不再传递给下一个处理者}
}class Order {// 订单的属性和方法
}class OrderProcessingChain {private val firstHandler: OrderHandlerinit {// 构建责任链// 设置责任链中的处理者顺序val inventoryCheckHandler = InventoryCheckHandler()val priceCalculationHandler = PriceCalculationHandler()val couponValidationHandler = CouponValidationHandler()val paymentHandler = PaymentHandler()inventoryCheckHandler.nextHandler = priceCalculationHandlerpriceCalculationHandler.nextHandler = couponValidationHandlercouponValidationHandler.nextHandler = paymentHandlerfirstHandler = inventoryCheckHandler}fun processOrder(order: Order) {// 将订单传递给责任链的第一个处理者firstHandler.handleOrder(order)}
}fun main() {val order = Order()val chain = OrderProcessingChain()chain.processOrder(order)
}
在OkHttp库中,okhttp3.Interceptor接口就使用了责任链模式,用于拦截和处理HTTP请求和响应。
Interceptor接口定义了一个方法intercept,该方法接收一个Chain对象作为参数,代表了整个拦截器链。Chain接口提供了对请求和响应的访问以及继续执行下一个拦截器的功能。
由于责任链模式的灵活性和可扩展性,所以当我们需要在OkHttp中添加自定义拦截器时(比如自定义日志拦截器),我们可以很容易地创建一个实现Interceptor接口的日志拦截器,并在其intercept方法中实现日志记录的逻辑。
class LoggingInterceptor : Interceptor {@Throws(IOException::class)override fun intercept(chain: Interceptor.Chain): Response {val request: Request = chain.request()// 记录请求信息val startTime = System.nanoTime()println("Sending request: ${request.url()}")val response: Responsetry {response = chain.proceed(request)} catch (e: IOException) {// 记录请求异常println("Request failed: ${e.message}")throw e}// 记录响应信息val endTime = System.nanoTime()val duration = endTime - startTimeprintln("Received response for ${request.url()} in ${duration / 1e6}ms")return response}
}
然后,将该自定义拦截器添加到OkHttpClient中的拦截器链中。
fun main() {val client = OkHttpClient.Builder().addInterceptor(LoggingInterceptor()).build()val request = Request.Builder().url("https://api.example.com").build()try {val response: Response = client.newCall(request).execute()// 处理响应} catch (e: IOException) {// 处理异常}
}
Thank you for your reading, best regards!😃😃
相关文章:
安卓常见设计模式10------责任链模式(Kotlin版)
1. W1 是什么,什么是责任链模式? 责任链模式(Chain of Responsibility Pattern)是一种行为型设计模式,它用于将请求的发送者和接收者解耦,并将请求沿着一个处理链进行传递,直到有一个处理者能…...
利用 Google Artifact Repository 构建maven jar 存储仓库
参考了google 官方文档 https://cloud.google.com/artifact-registry/docs/java/store-java#gcloud_1 首先 enable GAR api gcloud services enable artifactregistry.googleapis.com gcloud services list | grep -i artifact artifactregistry.googleapis.com Artifac…...
Facebook广告被暂停是什么原因?Facebook广告账号被封怎么办?
许多做海外广告投放的小伙伴经常遇到一个难题,那就是投放的Facebook广告被拒或 Facebook 广告帐户被关闭赞停的经历,随之而来的更可能是广告账户被封,导致资金的损失。本文将从我自身经验,为大家分享,Facebook广告被暂…...
Javaweb之javascript的BOM对象的详细解析
1.5.2 BOM对象 接下来我们学习BOM对象,BOM的全称是Browser Object Model,翻译过来是浏览器对象模型。也就是JavaScript将浏览器的各个组成部分封装成了对象。我们要操作浏览器的部分功能,可以通过操作BOM对象的相关属性或者函数来完成。例如:…...
使用Nginx和Spring Gateway为SkyWalking的增加登录认证功能
文章目录 1、使用Nginx增加认证。2、使用Spring Gateway增加认证 SkyWalking的可视化后台是没有用户认证功能的,默认下所有知道地址的用户都能访问,官网是建议通过网关增加认证。 本文介绍通过Nginx和Spring Gateway两种方式 1、使用Nginx增加认证。 生…...
Android 12.0 增加多张图片作为系统静态壁纸的功能实现
1.前言 在12.0的系统rom定制化开发中,在做系统定制化开发中,在对系统的静态壁纸做定制的时候,需要增加几种静态壁纸可以让用户自己设置壁纸,所以可以在壁纸的系统应用中 添加几种静态壁纸图片,然后配置好 就可以在选择壁纸的时候,作为静态壁纸,接下来看如何具体实现这个…...
无线优化之RRM模板
一、简介 RRM即,Radio Resource Management,射频资源管理 WLAN技术是以射频信号(如2.4G/5G的无线电磁波)作为传输介质,无线电磁波在传输过程中因周围环境导致无线信号衰减,从而影响无线用户上网的服务质量。 RRM模板主要用于保持最优的频射资源状态,自动检查周围无线…...
BI 数据可视化平台建设(1)—交叉表组件演变实战
作者:vivo 互联网大数据团队 - Zhu Jianchen 本文是vivo互联网大数据团队《BI数据可视化平台建设》系列文章第1篇 - 交叉表组件。 交叉表在数据分析里应用广泛,通过本文,你将了解到: 交叉表的基本概念,以及BI可视化平…...
Python---练习:求幸运数字6
案例: 幸运数字6(只要是6的倍数):输入任意数字,如数字8,生成nums列表,元素值为1~8,从中选取幸运数字移动到新列表lucky,打印nums与lucky。 思考: 要求是6的…...
【云栖2023】王峰:开源大数据平台3.0技术解读
本文根据2023云栖大会演讲实录整理而成,演讲信息如下: 演讲人:王峰 | 阿里云研究员,阿里云计算平台事业部开源大数据平台负责人 演讲主题:开源大数据平台3.0技术解读 实时化与Serverless是开源大数据3.0时代的必然选…...
如何改变Wi-Fi的IP地址,提高网络连接稳定性和速度
Wi-Fi已经成为我们日常生活中必不可少的一部分。大多数家庭和办公室都依赖于Wi-Fi来连接网络和进行各种在线活动。然而,有时我们可能会遇到网络连接不稳定或速度较慢的问题。这可能是由于IP地址的设置不当所导致的。虎观代理小二二将向您介绍如何改变Wi-Fi的IP地址&…...
APP 备案公钥、签名 MD5、SHA-1、SHA-256获取方法。
公钥和 MD5 值可以通过安卓开发工具、Keytool、Jadx-GUI 等多种工具获取,最简单的就是以 appuploader为例。 1.下载 appuploader工具 ,点击此处 下载 appuploader 工具。 2.下载完成后,解压压缩包,双击 appuploder 运行。 3.运…...
屏幕提词软件Presentation Prompter mac中文版使用方法
Presentation Prompter for mac是一款屏幕提词器软件,它可以将您的Mac电脑快速变成提词器,支持编写或导入,可以在一个或多个屏幕上平滑地滚动,Presentation Prompter 下载是为适用于现场表演者,新闻广播员,…...
Rc与Arc实现1vN所有权机制
Rc与Arc实现1vN所有权机制 观察引用计数的变化一个例子多线程无力的Rc< T >Arc Rust所有权机制要求一个值只能有一个所有者,在大多数情况下,都没有问题,但是考虑以下情况: 在图数据结构中,多个边可能会拥有同一个…...
建造者模式 rust和java的实现
文章目录 建造者模式介绍优点缺点使用场景 实现javarust rust代码仓库 建造者模式 建造者模式(Builder Pattern)使用多个简单的对象一步一步构建成一个复杂的对象。 一个 Builder 类会一步一步构造最终的对象。该 Builder 类是独立于其他对象的。 介绍…...
书写Prompt的经验总结
首先最重要的一点是Prompt无法全部模型都通用,可能你的Prompt在ChatGPT中使用很好,迁移到ChatGLM就不行了。不知道未来是否会出现Prompt的跨平台。 首先书写Prompt要明确告诉模型要做什么,而不是告诉它不要做什么。还要保证精简,…...
WebSocket实时应用
在开发一些前端页面的时候,总是能接收到这样的需求:如何保持页面并实现自动更新数据呢?以往的常规做法,是前端使用定时轮询后端接口,获取响应后重新渲染前端页面,这种做法虽然能达到类似的效果,…...
从零开始搭建React+TypeScript+webpack开发环境-基于lerna的webpack项目工程化改造
项目背景 在实际项目中,我们的前端项目往往是一个大型的Webpack项目,结构较为复杂。项目根目录下包含了各种配置文件、源代码、以及静态资源,整体布局相对扁平。Webpack的配置文件分散在不同的部分,包括入口文件、输出目录、加载…...
网络监控系统和防火墙的区别有哪些?
现如今,市面上保护企业网络安全的设备有很多,其中使用最多的当属网络监控系统和防火墙。 网络监控系统就是通过网页内容的自动采集处理、敏感词过滤、智能聚类分类、主题检测、专题聚焦、统计分析等多个环节,实现相关网络舆情监督管理的需要…...
刷题学习记录BUUCTF
[极客大挑战 2019]RCE ME1 进入环境直接就有代码 <?php error_reporting(0); if(isset($_GET[code])){$code$_GET[code];if(strlen($code)>40){die("This is too Long.");}if(preg_match("/[A-Za-z0-9]/",$code)){die("NO.");}eval($co…...
易语言中根据凸度求圆心角
在易语言中,根据凸度(Bulge)计算圆心角,其核心数学原理与通用公式 θ 4 * arctan(|bulge|) 完全一致 。实现的关键在于调用易语言的数学函数库,并遵循其特定的语法规则进行编码 。 一、核心计算函数实现 以下是一个…...
Degrees of Lewdity中文汉化版:完整安装指南与终极教程
Degrees of Lewdity中文汉化版:完整安装指南与终极教程 【免费下载链接】Degrees-of-Lewdity-Chinese-Localization Degrees of Lewdity 游戏的授权中文社区本地化版本 项目地址: https://gitcode.com/gh_mirrors/de/Degrees-of-Lewdity-Chinese-Localization …...
训练时train loss和val loss的‘爱恨情仇’:从曲线看懂模型到底在干嘛(附调参实战)
训练时train loss和val loss的‘爱恨情仇’:从曲线看懂模型到底在干嘛(附调参实战) 盯着训练日志里两条纠缠不清的loss曲线,是不是像在看一场情感大戏?train loss像热情似火的追求者,val loss则像若即若离的…...
从浏览器到桌面:3步将你的Twine游戏变成专业桌面应用 [特殊字符]
从浏览器到桌面:3步将你的Twine游戏变成专业桌面应用 🚀 【免费下载链接】twine-app-builder Automatically generate Windows and macOS versions of your Twine games, for free! 项目地址: https://gitcode.com/gh_mirrors/tw/twine-app-builder …...
滴滴测开面试复盘:从两道烧脑的智力题到‘猜数字’编程,我的真实面经与避坑指南
从智力题到编程实战:测开面试中的思维跃迁与避坑策略 当面试官推过来那张印着水桶问题的白纸时,我意识到这场面试远不止是技术栈的简单考察。5L和3L的水桶静静躺在纸上,却在我脑海里掀起了一场思维风暴。这或许正是现代测试开发岗位面试的精髓…...
紧急预警:Dify v0.12.3升级后Webhook签名机制变更!3类存量集成即将失效(附热修复补丁)
第一章:紧急预警:Dify v0.12.3升级后Webhook签名机制变更!3类存量集成即将失效(附热修复补丁) Dify v0.12.3 版本于 2024-06-15 正式发布,核心变更之一是强制启用 RFC 8941 兼容的 Webhook 签名验证机制&am…...
告别手动挖洞:用Acunetix 13.0自动化扫描你的Pikachu靶场(附详细配置与报告解读)
从零到精通的Acunetix实战:Pikachu靶场自动化安全评估指南 在网络安全学习的过程中,靶场环境就像武术训练中的木人桩,而自动化扫描工具则是帮助我们快速发现弱点的"火眼金睛"。本文将带你深入探索如何将Acunetix这款专业级扫描工具…...
5分钟完成Windows系统深度优化:Win11Debloat终极指南
5分钟完成Windows系统深度优化:Win11Debloat终极指南 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other changes to declutter and cus…...
终极指南:使用onnx2torch轻松实现ONNX到PyTorch模型转换
终极指南:使用onnx2torch轻松实现ONNX到PyTorch模型转换 【免费下载链接】onnx2torch Convert ONNX models to PyTorch. 项目地址: https://gitcode.com/gh_mirrors/on/onnx2torch 你是否正在寻找一种简单高效的方法,将训练好的ONNX模型转换为PyT…...
PyTorch DataLoader内存优化实战:num_workers和batch_size到底怎么调才不会崩?
PyTorch DataLoader内存优化实战:num_workers和batch_size到底怎么调才不会崩? 当你深夜盯着屏幕上突然出现的Killed报错,看着训练了3天的模型戛然而止,这种崩溃感每个深度学习开发者都懂。内存溢出就像悬在头上的达摩克利斯之剑—…...
