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

Matlab初识:什么是Matlab?它的历史、发展和应用领域

目录 一、什么是Matlab? 二、Matlab的历史与发展 三、Matlab的应用领域 四、安装和启动Matlab 五、界面介绍 六、第一个Matlab程序 七、总结 一、什么是Matlab? Matlab 是由 MathWorks 公司开发的一款用于数值计算、可视化以及编程的高级技术计算…...

大模型之-Seq2Seq介绍

大模型之-Seq2Seq介绍 1. Seq2Seq 模型概述 Seq2Seq(Sequence to Sequence)模型是一种用于处理序列数据的深度学习模型,常用于机器翻译、文本摘要和对话系统等任务。它的核心思想是将一个输入序列转换成一个输出序列。 Seq2Seq模型由两个主…...

NSSCTF-Web题目12

目录 [SWPUCTF 2021 新生赛]finalrce 1、题目 2、知识点 3、思路 [UUCTF 2022 新生赛]ez_rce 1、题目 2、知识点 3、思路 [羊城杯 2020]easycon 1、题目 2、知识点 3、思路 [SWPUCTF 2021 新生赛]finalrce 1、题目 2、知识点 命令执行,tee命令 3、思路…...

22、架构-资源与调度

1、资源与调度 调度是容器编排系统最核心的功能之一,“编排”一词本身便包 含“调度”的含义。调度是指为新创建的Pod找到一个最恰当的宿主机 节点来运行它,这个过程成功与否、结果恰当与否,关键取决于容器 编排系统是如何管理与分配集群节点…...

mac 常用工具命令集合

Iterm2 Command T:新建标签 Command W:关闭当前标签 Command ← →:在标签之间切换 Control U:清除当前行 Control A:跳转到行首 Control E:跳转到行尾 Command F:查找 Command …...

服务器雪崩的应对策略之----限流

限流是一种控制流量的技术,旨在防止系统在高并发请求下被压垮。通过限流,可以确保系统在负载高峰期依然能保持稳定运行。常见的限流策略包括令牌桶算法、漏桶算法、计数器算法和滑动窗口算法。 常见的限流方法 1. 令牌桶算法 (Token Bucket Algorithm)2…...

Python12 列表推导式

1.什么是列表推导式 Python的列表推导式(list comprehension)是一种简洁的构建列表(list)的方法,它可以从一个现有的列表中根据某种指定的规则快速创建一个新列表。这种方法不仅代码更加简洁,执行效率也很…...

threejs 光影投射-与场景进行交互(六)

效果 场景中有三个立方体,三种颜色.点击变成红色,再点恢复自身原有颜色 代码 import ./style.css import * as THREE from three import { OrbitControls } from three/examples/jsm/controls/OrbitControls.js import { log } from three/examples/jsm/nodes/Nodes.js//…...

Ubuntu 20.04安装显卡驱动、CUDA和cuDNN(2024.06最新)

一、安装显卡驱动 1.1 查看显卡型号 lspci | grep -i nvidia我们发现输出的信息中有Device 2230,可以根据这个信息查询显卡型号 查询网址:https://admin.pci-ids.ucw.cz/mods/PC/10de?actionhelp?helppci 输入后点击Jump查询 我们发现显卡型号为RTX …...

二叉树的这五种遍历方法你们都会了吗?

说在前面 🎈二叉树大家应该都很熟了吧,那二叉树的这五种遍历方式你们都会了吗? 以这一二叉树为例子,我们来看看不同遍历方式返回的结果都是怎样的。 前序遍历 前序遍历的顺序是:首先访问根节点,然后递归地…...

wordpress添加账户余额/谷歌账号注册入口官网

Spring Boot 热部署 实际开发中,修改某个页面数据或逻辑功能都需要重启应用。这无形中降低了开发效率,所以使用热部署是十分必要的。 什么是热部署? 应用启动后会把编译好的Class文件加载的虚拟机中,正常情况下在项目修改了源文件…...

html改造wordpress/太原做网站推广的公司

1 内核不可抢占,导致用户态程序的响应时间不可确定,这也是preempt-RT做的最大工作。kernel是抢占的,SHCED_RR和SCHED_FIFO都是高优先级可以抢占低优先级。2 内核少量关键区还是用的spin lock,这也是不可抢占的,us级别左…...

国外做的比较的ppt网站有哪些方面/抖音推广平台

行为树里有很多任务,导入这个包用来实现A星寻路或者其它导航。 线上安装: 搜索Behavior Designer Movement 导入Behavior Designer - Movement 导入后Actions任务里会多一个Movement...

网站翻页功能/免费私人网站建设

窗体抖动案例 首先将窗体在当前屏幕居中 其次使用for循环实现都行的次数 最后利用left,top实现窗体的抖动 private void Form2_Load(object sender, EventArgs e){this.CenterToScreen();//将窗体在当前屏幕居中}private void button1_Click(object sender, EventArgs e)//…...

微信网站开发/谷歌搜图

1 过滤器HBase 的基本 API,包括增、删、改、查等。增、删都是相对简单的操作,与传统的 RDBMS 相比,这里的查询操作略显苍白,只能根据特性的行键进行查询(Get)或者根据行键的范围来查询(Scan&…...

古镇小企业网站建设/简单的seo

📖摘要 今天分享下 —— VsCode系列:11个必备 VS Code 插件 的一些基本知识,欢迎关注! 🌂提升开发效率的插件 1. Better Comments Better Comments 你可以使用不同的前缀来让注释显示为不同的颜色。非常适合快速扫描并…...