当前位置: 首页 > 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写作工具可以提升我们的创作效率,快速的生成文章,然后在根据需求进行调整修改即可。下…...

19c补丁后oracle属主变化,导致不能识别磁盘组

补丁后服务器重启,数据库再次无法启动 ORA01017: invalid username/password; logon denied Oracle 19c 在打上 19.23 或以上补丁版本后,存在与用户组权限相关的问题。具体表现为,Oracle 实例的运行用户(oracle)和集…...

Redis相关知识总结(缓存雪崩,缓存穿透,缓存击穿,Redis实现分布式锁,如何保持数据库和缓存一致)

文章目录 1.什么是Redis?2.为什么要使用redis作为mysql的缓存?3.什么是缓存雪崩、缓存穿透、缓存击穿?3.1缓存雪崩3.1.1 大量缓存同时过期3.1.2 Redis宕机 3.2 缓存击穿3.3 缓存穿透3.4 总结 4. 数据库和缓存如何保持一致性5. Redis实现分布式…...

【服务器压力测试】本地PC电脑作为服务器运行时出现卡顿和资源紧张(Windows/Linux)

要让本地PC电脑作为服务器运行时出现卡顿和资源紧张的情况,可以通过以下几种方式模拟或触发: 1. 增加CPU负载 运行大量计算密集型任务,例如: 使用多线程循环执行复杂计算(如数学运算、加密解密等)。运行图…...

在WSL2的Ubuntu镜像中安装Docker

Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...

如何理解 IP 数据报中的 TTL?

目录 前言理解 前言 面试灵魂一问:说说对 IP 数据报中 TTL 的理解?我们都知道,IP 数据报由首部和数据两部分组成,首部又分为两部分:固定部分和可变部分,共占 20 字节,而即将讨论的 TTL 就位于首…...

力扣-35.搜索插入位置

题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)

上一章用到了V2 的概念,其实 Fiori当中还有 V4,咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务),代理中间件(ui5-middleware-simpleproxy)-CSDN博客…...

Unsafe Fileupload篇补充-木马的详细教程与木马分享(中国蚁剑方式)

在之前的皮卡丘靶场第九期Unsafe Fileupload篇中我们学习了木马的原理并且学了一个简单的木马文件 本期内容是为了更好的为大家解释木马(服务器方面的)的原理,连接,以及各种木马及连接工具的分享 文件木马:https://w…...

Pinocchio 库详解及其在足式机器人上的应用

Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库,专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性,并提供了一个通用的框架&…...

Spring是如何解决Bean的循环依赖:三级缓存机制

1、什么是 Bean 的循环依赖 在 Spring框架中,Bean 的循环依赖是指多个 Bean 之间‌互相持有对方引用‌,形成闭环依赖关系的现象。 多个 Bean 的依赖关系构成环形链路,例如: 双向依赖:Bean A 依赖 Bean B,同时 Bean B 也依赖 Bean A(A↔B)。链条循环: Bean A → Bean…...