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

整理好了!2024年最常见 20 道设计模式面试题(九)

上一篇地址:整理好了!2024年最常见 20 道设计模式面试题(八)-CSDN博客

十七、什么是享元模式?它在资源优化中扮演什么角色?

享元模式(Flyweight Pattern)是一种常用的软件设计模式,属于结构型设计模式。它主要用于减少创建对象的数量,以减少内存占用和提高性能,这在资源优化中扮演着重要角色。

享元模式的定义:

享元模式提供了一种通过共享来高效使用资源的策略。这种模式涉及到一个共享对象池,这个池中的对象可以被多个客户端共享。如果一个对象在使用时需要额外的状态,享元模式会通过外部化这些状态来确保共享对象可以被多个客户端使用,而不相互干扰。

享元模式的组成:

  1. 享元对象(Flyweight):享元模式的核心,是被共享的对象。它包含内部状态,这些状态可以被多个客户端共享。
  2. 享元工厂(Flyweight Factory):负责创建和管理享元对象,确保享元对象可以被正确地共享。
  3. 客户端(Client):使用享元对象的代码,它通过享元工厂获取享元对象,并可能向享元对象传递外部状态。

享元模式的角色在资源优化中的作用:

  1. 减少对象数量:通过共享对象,享元模式减少了需要创建的对象数量,从而减少了内存的使用。
  2. 提高性能:由于减少了对象的创建和销毁,享元模式可以提高应用程序的性能,尤其是在对象创建成本高的情况下。
  3. 优化资源使用:享元模式通过共享对象,使得资源的使用更加高效,特别是在处理大量相似对象时。

应用场景:

  • 当一个应用程序使用了大量的相似对象,而这些对象的状态大部分可以共享时。
  • 当对象的创建成本很高,或者对象的存储成本很高时。
  • 当需要减少应用程序的内存占用,提高响应速度时。

示例:

假设我们有一个文本编辑器,需要显示大量的字符。如果每个字符都是一个独立的对象,那么内存使用将会非常巨大。使用享元模式,我们可以创建一个字符享元对象池,每个字符对象共享相同的字体、大小等属性,而每个字符的唯一状态(如字符本身)则作为外部状态传递给享元对象。

通过这种方式,享元模式帮助我们在保持对象功能的同时,优化了资源的使用,提高了应用程序的效率。

十八、请解释解释器模式,并给出一个使用场景。

解释器模式(Interpreter Pattern)是一种行为型设计模式,它提供了一种定义语言的语法规则的方法,并且能够解释和执行这些规则。这种模式通常用于实现简单的脚本语言、解析表达式或者定义领域特定语言。

解释器模式的定义:

解释器模式允许你将操作以一种特定的语法规则表示出来,然后解释这些规则以执行相应的操作。它通常包括一个表达式抽象类、具体表达式类以及一个解释器类。

解释器模式的组成:

  1. 抽象表达式(Abstract Expression):定义了一个抽象的解释操作,通常包含一个抽象的interpret方法。
  2. 终端表达式(Terminal Expression):实现了抽象表达式,代表语法规则中的终端符号。
  3. 非终端表达式(Non-terminal Expression):也实现了抽象表达式,代表语法规则中的非终端符号。
  4. 上下文(Context):包含解释器之外的一些全局信息,可能被解释器中的表达式所使用。
  5. 客户端(Client):构建一个特定的语法结构,并使用解释器来解释它。

解释器模式的使用场景:

  1. 当有一个语言需要解释执行时。
  2. 当需要创建一个简单的语法分析器时。
  3. 当需要将一个简单的语法规则集转换成一个抽象语法树(AST)时。

示例:

假设我们需要实现一个简单的计算器,它可以解析和执行基本的算术表达式,如加法、减法、乘法和除法。使用解释器模式,我们可以这样实现:

  1. 抽象表达式:定义一个抽象类Expression,包含一个interpret方法。
  2. 终端表达式:创建NumberExpression类,表示数字,实现interpret方法。
  3. 非终端表达式:创建AddExpressionSubtractExpressionMultiplyExpressionDivideExpression类,分别表示加、减、乘、除操作,它们都继承自Expression类,并实现interpret方法。
  4. 上下文Context类,包含当前的数值。
  5. 解释器CalculatorInterpreter类,使用上下文来解析和执行表达式。

使用场景代码示例(伪代码):

class Expression {abstract interpret(Context context);
}class NumberExpression extends Expression {int number;interpret(Context context) {context.push(number);}
}class AddExpression extends Expression {Expression left, right;interpret(Context context) {right.interpret(context);left.interpret(context);context.add();}
}// 其他表达式类类似 AddExpression ...class Context {stack;push(int value) { stack.push(value); }pop() { return stack.pop(); }add() { stack.top += stack.next.pop(); }// 其他操作 ...
}class CalculatorInterpreter {Expression parse(String expression);void interpret(String expression) {Expression exp = parse(expression);Context context = new Context();exp.interpret(context);}
}// 客户端使用
CalculatorInterpreter interpreter = new CalculatorInterpreter();
interpreter.interpret("3 + 4 * 2 - 5");

在这个例子中,解释器模式允许我们以一种结构化的方式构建和解析算术表达式,然后执行它们。这种模式非常适合于需要解析和执行简单语言或表达式的场景。

相关文章:

整理好了!2024年最常见 20 道设计模式面试题(九)

上一篇地址:整理好了!2024年最常见 20 道设计模式面试题(八)-CSDN博客 十七、什么是享元模式?它在资源优化中扮演什么角色? 享元模式(Flyweight Pattern)是一种常用的软件设计模式…...

RAG实操教程langchain+Milvus向量数据库创建你的本地知识库 二

Miluvs 向量数据库 关于 Milvui 可以参考我的前两篇文章 • 一篇文章带你学会向量数据库Milvus(一)[1]• 一篇文章带你学会向量数据库Milvus(二)[2] 下面我们安装 pymilvus 库 pip install --upgrade --quiet pymilvus如果你…...

Spring+SpringMVC介绍+bean实例化+依赖注入实战

Spring介绍 Spring是一个轻量级的Java 开发框架,核心是IOC(控制反转)和AOP(面向切面编程) Spring解决了业务层(Service包)与其他各层(表现层,包括Model,Vie…...

【安装笔记-20240616-Linux-为 OpenWrt 自动挂载 Windows 主机共享目录】

安装笔记-系列文章目录 安装笔记-20240616-Linux-为 OpenWrt 自动挂载 Windows 主机共享目录 文章目录 安装笔记-系列文章目录安装笔记-20240616-Linux-为 OpenWrt 自动挂载 Windows 主机共享目录 前言一、软件介绍名称:cifsutils主页官方介绍特点 二、安装步骤测试…...

61.WEB渗透测试-信息收集- WAF、框架组件识别(1)

免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 内容参考于: 易锦网校会员专享课 上一个内容:60.WEB渗透测试-信息收集- 端口、目录扫描、源码泄露(8) WAF的识…...

qmt量化交易策略小白学习笔记第45期【qmt编程之期货行情数据--如何获取日线行情、tick行情】

qmt编程之获取期货行情数据 qmt更加详细的教程方法,会持续慢慢梳理。 也可找寻博主的历史文章,搜索关键词查看解决方案 ! 感谢关注,咨询免费开通量化回测与获取实盘权限,欢迎和博主联系! 获取日线行情数…...

c#default 运算符

值类型默认值boolfalsebyte0char‘\0’decimal0.0Mdouble0.0Denum表达式 (E)0 产生的值,其中 E 为 enum 标识符。float0.0Fint0long0Lsbyte0short0struct将所有的值类型字段设置为默认值并将所有的引用类型字段设置为 null 时产生的值。uint0ulong0ushort0引用类型n…...

25计算机考研,这所985有机会!

吉林大学的计算机学科评估是A-,软件是B 实力还是很强的! 考研的专科课代码分别是941和966 其实就是自命题,941是四合一:数据结构,计算机组成与设计,操作系统和计算机网络,这个和408统考的科目…...

SQL 基础入门教程

目录 什么是 SQL? SQL 的基本操作 数据库的创建和删除 表的创建和删除 数据的插入 数据的查询 数据的更新 数据的删除 SQL 的高级操作 表的连接 聚合函数 分组和排序 子查询 视图 索引 SQL 的数据完整性和约束 总结 SQL(Structured Que…...

<Python><paddleocr>基于python使用百度paddleocr实现图片文字识别与替换

前言 本文是使用百度的开源库paddleocr来实现对图片文字的识别,准确度还不错,对图片文字的替换,则利用opencv来完成。 环境配置 系统:windows 平台:visual studio code 语言:python 库:paddleocr、opencv、pyqt5 依赖库安装 本例所需要的库可以直接用pip来安装。 安装…...

小程序开发的费用简介篇

小程序的价格跟很多因素有关系,比如你想要的复杂度、功能多不多等等 今天我就来具体说说开发一款APP/小程序到底需要多少 ❶功能复杂度:功能越多越复杂,开发时间和费用就越高,费用就会高 ❷设计要求:高级的…...

torch.unflod与torch.nn.functional.pad用法

PyTorch 中的两个函数:torch.unfold 和 torch.nn.unfold。它们分别用于不同的目的,让我们分别来理解一下: torch.nn.Unfold 类功能: 类似于函数 torch.unfold,torch.nn.Unfold 类也用于沿着指定维度滑动提取窗口并将每个窗口展平。与函数不同的是,torch.nn.Unfold 是一个…...

江苏 服务器性能监控包含哪些方面?

服务器的性能监控主要是为了确保服务器能够正常运行工作和性能优化的重要手段,接下来就来看一下服务器性能监控所包含的内容有哪些吧! 首先对于服务器的系统资源进行一定的监控,CPU作为服务器的核心组件之一,所以我们要监控CPU的使…...

卓越的 App UI 风格引领潮流

卓越的 App UI 风格引领潮流...

BirdTalk IM集群中消息流转策略讨论

BirdTalk IM集群中消息流转策略讨论 目前群聊的存储策略是1写多读方案;每个群组一个队列,按时间顺序排列,不区分用户; 私聊的存储是写扩散的,每个人都有自己的消息队列,按时间顺序 保存所有的消息&#x…...

重磅!2024年最新影响因子正式发布,附Excel下载

大家好,这里是专注表观组学十余年,领跑多组学科研服务的易基因。 激动人心的时刻终于来了,2024年影响因子已全面发布!废话不多说,大家一起来看看最新的发布的结果吧! 神刊:CA-A CANCER JOURNA…...

【会议征稿】2024年应用计算智能、信息学与大数据国际会议(ACIIBD 2024,7月26-28)

2024年应用计算智能、信息学与大数据国际学术会议(ACIIBD 2024)将于2024年7月26-28日在中国广州举办。会议将聚焦于计算智能及其应用、信息、大数据等相关的研究领域, 广泛邀请国内外知名专家学者,共同探讨相关学科领域的最新发展…...

【代码发布】Quantlab4.3:lightGBM应用于全球大类资产的多因子智能策略(代码+数据)

原创文章第566篇,专注“AI量化投资、世界运行的规律、个人成长与财富自由"。 昨天,Quantlab整合Alpha158因子集,为机器学习大类资产配置策略做准备(代码数据),我们完成了因子集构建,并尝试…...

【毕业设计】Django 校园二手交易平台(有源码+mysql数据)

此项目有完整实现源码,有需要请联系博主 Django 校园二手交易平台开发项目 项目选择动机 本项目旨在开发一个基于Django的校园二手交易平台,为大学生提供一个安全便捷的二手物品买卖平台。该平台将提供用户注册和认证、物品发布和搜索、交易信息管理等…...

文章自动生成器,在线AI写作工具

随着人工智能AI技术的发展,AI技术被应用到越来越多的场景。对于需要创作内容的同学来说,AI写作-文章内容自动生成器是一个非常好的辅助工具。AI写作工具可以提升我们的创作效率,快速的生成文章,然后在根据需求进行调整修改即可。下…...

装饰模式(Decorator Pattern)重构java邮件发奖系统实战

前言 现在我们有个如下的需求,设计一个邮件发奖的小系统, 需求 1.数据验证 → 2. 敏感信息加密 → 3. 日志记录 → 4. 实际发送邮件 装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其…...

VB.net复制Ntag213卡写入UID

本示例使用的发卡器:https://item.taobao.com/item.htm?ftt&id615391857885 一、读取旧Ntag卡的UID和数据 Private Sub Button15_Click(sender As Object, e As EventArgs) Handles Button15.Click轻松读卡技术支持:网站:Dim i, j As IntegerDim cardidhex, …...

FastAPI 教程:从入门到实践

FastAPI 是一个现代、快速(高性能)的 Web 框架,用于构建 API,支持 Python 3.6。它基于标准 Python 类型提示,易于学习且功能强大。以下是一个完整的 FastAPI 入门教程,涵盖从环境搭建到创建并运行一个简单的…...

渗透实战PortSwigger靶场-XSS Lab 14:大多数标签和属性被阻止

<script>标签被拦截 我们需要把全部可用的 tag 和 event 进行暴力破解 XSS cheat sheet&#xff1a; https://portswigger.net/web-security/cross-site-scripting/cheat-sheet 通过爆破发现body可以用 再把全部 events 放进去爆破 这些 event 全部可用 <body onres…...

2024年赣州旅游投资集团社会招聘笔试真

2024年赣州旅游投资集团社会招聘笔试真 题 ( 满 分 1 0 0 分 时 间 1 2 0 分 钟 ) 一、单选题(每题只有一个正确答案,答错、不答或多答均不得分) 1.纪要的特点不包括()。 A.概括重点 B.指导传达 C. 客观纪实 D.有言必录 【答案】: D 2.1864年,()预言了电磁波的存在,并指出…...

【机器视觉】单目测距——运动结构恢复

ps&#xff1a;图是随便找的&#xff0c;为了凑个封面 前言 在前面对光流法进行进一步改进&#xff0c;希望将2D光流推广至3D场景流时&#xff0c;发现2D转3D过程中存在尺度歧义问题&#xff0c;需要补全摄像头拍摄图像中缺失的深度信息&#xff0c;否则解空间不收敛&#xf…...

LLM基础1_语言模型如何处理文本

基于GitHub项目&#xff1a;https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken&#xff1a;OpenAI开发的专业"分词器" torch&#xff1a;Facebook开发的强力计算引擎&#xff0c;相当于超级计算器 理解词嵌入&#xff1a;给词语画"…...

【JavaSE】绘图与事件入门学习笔记

-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角&#xff0c;以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向&#xff0c;距离坐标原点x个像素;第二个是y坐标&#xff0c;表示当前位置为垂直方向&#xff0c;距离坐标原点y个像素。 坐标体系-像素 …...

IoT/HCIP实验-3/LiteOS操作系统内核实验(任务、内存、信号量、CMSIS..)

文章目录 概述HelloWorld 工程C/C配置编译器主配置Makefile脚本烧录器主配置运行结果程序调用栈 任务管理实验实验结果osal 系统适配层osal_task_create 其他实验实验源码内存管理实验互斥锁实验信号量实验 CMISIS接口实验还是得JlINKCMSIS 简介LiteOS->CMSIS任务间消息交互…...

Device Mapper 机制

Device Mapper 机制详解 Device Mapper&#xff08;简称 DM&#xff09;是 Linux 内核中的一套通用块设备映射框架&#xff0c;为 LVM、加密磁盘、RAID 等提供底层支持。本文将详细介绍 Device Mapper 的原理、实现、内核配置、常用工具、操作测试流程&#xff0c;并配以详细的…...