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

设计模式 创建型 原型模式(Prototype Pattern)与 常见技术框架应用 解析

在这里插入图片描述

原型模式(Prototype Pattern)是一种创建型设计模式,其核心思想在于通过复制现有的对象(原型)来创建新的对象,而非通过传统的构造函数或类实例化方式。这种方式在需要快速创建大量相似对象时尤为高效,因为它避免了重复的初始化过程。

一、核心思想

原型模式的核心思想是“克隆”生成对象,即基于一个已经存在的对象(原型)来创建新的对象实例。这样做的好处是可以提高对象创建的效率,特别是在对象初始化过程复杂或资源消耗大的情况下。

二、定义与结构

定义

原型模式使用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新的对象。

结构

原型模式主要包含以下几个角色:

  1. Prototype(抽象原型类):声明一个克隆自己的操作,通常是一个Clone方法。这个接口或抽象类是所有具体原型类的基类。
  2. ConcretePrototype(具体原型类):实现原型接口,提供具体的Clone方法来返回对象的副本。
  3. Client(客户类):创建一个原型对象,并通过调用该对象的克隆方法来创建新的对象实例。
角色

在原型模式中,各个角色分工明确:

  • Prototype:定义了克隆方法的接口,可以是抽象类或接口。
  • ConcretePrototype:实现了Prototype接口,提供了具体的克隆实现。
  • Client:使用原型类来创建新对象的副本。

三、实现步骤及代码示例

以Java为例,展示原型模式的实现步骤和代码示例:

1、定义抽象原型类

public abstract class Prototype implements Cloneable {public abstract void show();// 克隆方法public Object clone() throws CloneNotSupportedException {return super.clone();}
}

2、实现具体原型类

public class ConcretePrototype1 extends Prototype {private String name;public ConcretePrototype1(String name) {this.name = name;}@Overridepublic void show() {System.out.println("ConcretePrototype1: " + name);}
}public class ConcretePrototype2 extends Prototype {private String description;public ConcretePrototype2(String description) {this.description = description;}@Overridepublic void show() {System.out.println("ConcretePrototype2: " + description);}
}

3、客户端代码

public class Client {public static void main(String[] args) {try {Prototype prototype1 = new ConcretePrototype1("Prototype 1");Prototype clonedPrototype1 = (Prototype) prototype1.clone();prototype1.show();clonedPrototype1.show();Prototype prototype2 = new ConcretePrototype2("Prototype 2");Prototype clonedPrototype2 = (Prototype) prototype2.clone();prototype2.show();clonedPrototype2.show();} catch (CloneNotSupportedException e) {e.printStackTrace();}}
}

在这个示例中,ConcretePrototype1ConcretePrototype2是具体原型类,它们实现了Prototype接口中的clone方法和show方法。客户端代码通过创建原型对象并调用其clone方法来创建新的对象实例,并展示它们的信息。

四、常见技术框架应用

虽然原型模式在Java等后端语言中更为常见,但在前端技术框架中,如JavaScript(特别是ES6及以后版本),也可以通过对象字面量、Object.create()方法或类(class)来实现类似的功能。

1、使用原生 JavaScript 实现简单原型模式

// 抽象原型(这里简单模拟,以对象形式包含 clone 方法规范)
const prototypeObj = {clone: function () {let clone = Object.create(this);clone.clone = this.clone;return clone;}
};// 具体原型:商品卡片原型
const productCardPrototype = Object.create(prototypeObj);
productCardPrototype.image = 'default.jpg';
productCardPrototype.title = 'Default Product';
productCardPrototype.price = 0;// 创建具体商品卡片实例
const productCard1 = productCardPrototype.clone();
productCard1.image = 'product1.jpg';
productCard1.title = 'Awesome Product 1';
productCard1.price = 19.99;const productCard2 = productCardPrototype.clone();
productCard2.image = 'product2.jpg';
productCard2.title = 'Fantastic Product 2';
productCard2.price = 29.99;console.log(productCard1);
console.log(productCard2);

在上述代码中:

  • 首先定义 prototypeObj 作为抽象原型基础,其 clone 方法利用 Object.create 基于当前对象(this)创建新对象,并为新对象也挂载 clone 方法,确保克隆能力延续。
  • productCardPrototype 作为具体原型,继承自抽象原型,初始化一些默认属性。
  • 最后通过多次调用 clone 方法创建不同的商品卡片实例,并按需修改各自属性。

结合 ES6 类实现更规范的原型模式

// 抽象原型(以抽象类形式)
class Prototype {constructor() {}clone() {throw new Error('Abstract clone method must be implemented.');}
}// 具体原型:员工信息原型
class EmployeePrototype extends Prototype {constructor(name, age, position) {super();this.name = name;this.age = age;this.position = position;}clone() {return new EmployeePrototype(this.name, this.age, this.position);}
}// 客户端使用
const originalEmployee = new EmployeePrototype('John Doe', 30, 'Developer');
const clonedEmployee = originalEmployee.clone();
clonedEmployee.name = 'Jane Smith';console.log(originalEmployee);
console.log(clonedEmployee);

这里:

  • Prototype 抽象类定义基本结构,clone 方法抛出错误强制子类实现。
  • EmployeePrototype 具体类继承自抽象类,在 clone 方法中通过构造函数创建新的员工对象副本,实现属性复制。
  • 客户端按需求克隆员工对象并修改个别属性。

2、在 React 中的应用

在 React 组件开发中,当需要创建相似的组件实例时,原型模式可间接体现。例如,有一个自定义的 Button 组件:

import React from 'react';// 基础按钮组件(类似原型)
const BaseButton = ({ text, onClick }) => {return <button onClick={onClick}>{text}</button>;
};// 创建不同样式的按钮实例
const PrimaryButton = (props) => <BaseButton {...props} className="primary-button" />;
const SecondaryButton = (props) => <BaseButton {...props} className="secondary-button" />;const App = () => {const handleClick = () => {console.log('Button clicked');};return (<div><PrimaryButton text="Submit" onClick={handleClick} /><SecondaryButton text="Cancel" onClick={handleClick} /></div>);
};export default App;

这里 BaseButton 可看作原型,PrimaryButtonSecondaryButton 通过复用 BaseButton 的结构,传递不同的 className 属性来生成具有不同样式的按钮实例,类似基于原型的克隆思想,快速构建相似但有差异的组件。

3、在 Vue 中的应用

以 Vue 组件为例,假设有一个模态框(Modal)组件:

<template><div class="modal" v-show="isVisible"><div class="modal-content"><h3>{{ title }}</h3><p>{{ message }}</p><button @click="closeModal">Close</button></div></div>
</template><script>
export default {name: 'Modal',data() {return {isVisible: false,title: 'Default Modal',message: 'This is a default message.'};},methods: {closeModal() {this.isVisible = false;}}
};
</script><style scoped>
.modal {/* 样式定义 */
}
.modal-content {/* 样式定义 */
}
</style>

若要创建多个不同内容的模态框,可在父组件中:

<template><div><Modal ref="modal1" :title="customModal1Title" :message="customModal1Message" /><Modal ref="modal2" :title="customModal2Title" :message="customModal2Message" /><button @click="openModal1">Open Modal 1</button><button @click="openModal2">Open Modal 2</button></div>
</template><script>
import Modal from './Modal.vue';export default {components: { Modal },data() {return {customModal1Title: 'Special Modal 1',customModal1Message: 'This is a custom message for modal 1.',customModal2Title: 'Unique Modal 2',customModal2Message: 'Another custom message for modal 2.'};},methods: {openModal1() {this.$refs.modal1.isVisible = true;},openModal2() {this.$refs.modal2.isVisible = true;}}
};
</script>

这里 Modal 组件作为原型,父组件通过传入不同的 titlemessage 属性,类似克隆并定制化模态框实例,满足不同业务场景需求,减少重复代码编写。

五、应用场景

原型模式适用于以下场景:

  1. 避免创建代价高昂的对象:当对象的创建过程非常复杂或昂贵时,可以使用原型模式来避免重复创建。
  2. 减少初始化时间:对于需要频繁创建但内容变化不大的对象,原型模式可以显著减少初始化时间。
  3. 共享技术配置:在应用程序中,如果多个对象共享相同的技术配置,可以使用原型模式来简化配置管理。
  4. 缓存池实现:在需要大量相似对象的情况下,原型模式可以用于缓存池的实现,以提高系统性能。
  5. 游戏开发中的角色复制:在游戏中,经常需要复制游戏中的角色或对象,原型模式非常适合这类需求。
  6. 数据备份和恢复:在数据备份和恢复过程中,原型模式可以用来快速创建数据的副本。
  7. 分布式系统中的对象复制:在分布式系统中,有时需要在不同的节点之间复制对象,原型模式可以帮助实现这一点。
  8. 测试用例生成:在自动化测试中,可以通过原型模式快速生成相似的测试用例,提高测试效率。
  9. 多线程环境下的对象共享:在多线程环境中,有时需要共享某些对象,原型模式可以帮助实现对象的安全共享。
  10. 数据库对象的复制:在数据库操作中,有时需要复制数据库对象,原型模式可以帮助简化这一过程。
  11. 图形用户界面(GUI)组件的复制:在GUI开发中,有时需要复制界面组件,原型模式可以实现这一点。
  12. 配置文件的解析和生成:在处理配置文件时,原型模式可以用来解析和生成配置文件。
  13. 网络请求的模拟:在网络编程中,有时需要模拟网络请求,原型模式可以帮助实现这一点。
  14. 事件处理机制:在事件处理机制中,有时需要复制事件对象,原型模式可以帮助实现这一点。
  15. 资源管理:在资源管理中,有时需要复制资源对象,原型模式可以帮助实现这一点。
  16. 版本控制系统中的文件比较:在版本控制系统中,有时需要比较文件的不同版本,原型模式可以帮助实现这一点。
  17. 文档编辑软件中的样式复制:在文档编辑软件中,有时需要复制样式,原型模式可以帮助实现这一点。
  18. 图像处理软件中的滤镜复制:在图像处理软件中,有时需要复制滤镜,原型模式可以帮助实现这一点。
  19. 音频处理软件中的音效复制:在音频处理软件中,有时需要复制音效,原型模式可以帮助实现这一点。
  20. 视频处理软件中的特效复制:在视频处理软件中,有时需要复制特效,原型模式可以帮助实现这一点。
  21. 虚拟现实(VR)环境中的对象复制:在虚拟现实环境中,有时需要复制虚拟对象,原型模式可以帮助实现这一点。
  22. 增强现实(AR)环境中的对象复制:在增强现实环境中,有时需要复制增强对象,原型模式可以帮助实现这一点。
  23. 机器学习模型的复制:在机器学习中,有时需要复制模型,原型模式可以帮助实现这一点。
  24. 深度学习网络的复制:在深度学习中,有时需要复制神经网络,原型模式可以帮助实现这一点。
  25. 自然语言处理(NLP)任务中的文本处理:在自然语言处理任务中,有时需要复制文本对象,原型模式可以帮助实现这一点。
  26. 计算机视觉任务中的图像处理:在计算机视觉任务中,有时需要复制图像对象,原型模式可以帮助实现这一点。
  27. 语音识别任务中的音频处理:在语音识别任务中,有时需要复制音频对象,原型模式可以帮助实现这一点。
  28. 推荐系统中的用户行为分析:在推荐系统中,有时需要分析用户的行为数据,原型模式可以帮助实现这一点。
  29. 电子商务平台中的商品信息复制:在电子商务平台中,有时需要复制商品信息,原型模式可以帮助实现这一点。
  30. 社交媒体平台上的内容分享:在社交媒体平台上,有时需要分享内容,原型模式可以帮助实现这一点。

六、优缺点

优点

  1. 性能提高:通过复制现有对象来创建新对象,避免了重复的初始化过程,提高了性能。
  2. 灵活性:可以动态地添加和删除原型对象,客户端可以直接使用新增的原型来实例化对象。
  3. 简化代码:避免了重复的代码编写,提高了代码的可维护性和可读性。

缺点

  1. 浅拷贝问题:如果原型对象包含引用类型的成员变量,那么这些成员变量所引用的对象将在原型对象和新对象之间共享,可能会导致意外的副作用。需要特别注意实现深拷贝。
  2. 复杂性增加:实现深拷贝可能会增加代码的复杂性。
  3. 可维护性挑战:如果类的结构中含有许多内部状态,而且这些状态随着时间不断变化,那么维护一个准确的克隆状态可能会非常困难。

综上所述,原型模式是一种高效且灵活的创建型设计模式,适用于需要快速创建大量相似对象的场景。然而,在使用时需要注意浅拷贝和深拷贝的问题,以及可能带来的复杂性和可维护性挑战。

在这里插入图片描述

相关文章:

设计模式 创建型 原型模式(Prototype Pattern)与 常见技术框架应用 解析

原型模式&#xff08;Prototype Pattern&#xff09;是一种创建型设计模式&#xff0c;其核心思想在于通过复制现有的对象&#xff08;原型&#xff09;来创建新的对象&#xff0c;而非通过传统的构造函数或类实例化方式。这种方式在需要快速创建大量相似对象时尤为高效&#x…...

cnPuTTY 0.82.0.1—PuTTY Release 0.82中文版本简单说明~~

2024-11-27 官方发布PuTTY 0.82主要包含如下变化&#xff1a; 1.Unicode处理进行了重大重构&#xff0c;以允许使用系统默认配置的字符集/代码页之外的Unicode字符。仅部分实现&#xff0c;其他尚未完成。 2.Unicode版本进行更新&#xff1a;所有字符分析均已更…...

TypeScript 常用类型

文章目录 1. 类型注解2. 原始类型3. 数组类型4. 联合类型5. 类型别名6. 函数类型7. 对象类型8. 接口类型8.1 接口声明8.2 接口继承 9. 元组类型10. 类型断言11. 字面量类型12. 枚举类型12.1 数字枚举12.2 字符串枚举 13. any 类型14. typeof 运算符 1. 类型注解 前言&#xff1…...

综合能源建模:理论、方法与实践

一、引言 随着全球能源需求的持续增长以及对能源安全、环境保护和可持续性发展的日益关注&#xff0c;综合能源系统&#xff08;Integrated Energy System&#xff0c;IES&#xff09;作为一种能够整合多种能源资源、实现能源高效利用和协同优化的解决方案&#xff0c;正逐渐成…...

《摄影艺术创作》慕课期末答案

《摄影艺术创作》慕课期末考试答案 题数 100 人们常说&#xff0c;“百闻不如一见”、“一图胜千言”&#xff0c;这强调的是 的表现力。 A视觉形象 B文字语言 C音响元素 D有声语言 “绘画是加法&#xff0c;摄影是减法”&#xff0c;主要是指无论摄影和绘画&#xff0c;都要…...

MySQL实用SQL示例

创建数据库 CREATE DATABASE zq-cloud CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;创建表 CREATE TABLE regulatory_firm_category (category_id int NOT NULL AUTO_INCREMENT COMMENT 分类id&#xff0c;自增主键,parent_id int NOT NULL COMMENT 父级id,category_…...

MySQL日志

MySQL日志 文章目录 MySQL日志binlogredoundoredo vs undo binlog binlog日志也就是二进制日志&#xff0c;把对于数据库的写入操作以二进制的形式保存到磁盘中。binlog日志是mysql的逻辑日志&#xff0c;可以理解为记录的是sql日志&#xff0c;由mysql的服务层进行记录&#…...

双目的一些文章学习

文章1 PSMNet https://arxiv.org/pdf/1803.08669PSMNet文章博客PSMNet文章中牵涉到的一些知识&#xff0c;空洞卷积&#xff0c;SPPNet网络&#xff0c;计算视差时用soft argmin代替argmin文章中引入了空洞卷积和SPPNet网络来融合多尺度的信息&#xff0c;又引入3D卷积来增加模…...

国产文本编辑器EverEdit - 批量转码转换行符

1 批量转码&转换行符 1.1 应用场景 如果用户批量在Windows编辑文件&#xff0c;要上传到异构系统&#xff0c;如&#xff1a;Linux&#xff0c;则需要批量转换编码和换行符&#xff0c;此时可以使用EverEdit的批量转码功能。 1.2 使用方法 选择主菜单文档 -> 批量转码…...

NextCloud服务安装与配置教程

NextCloud服务安装与配置教程 什么是 NextCloud: Nextcloud 是一款开源的私有云存储和协作平台,允许用户在自己的服务器上托管数据并管理团队协作。它可以作为一个功能丰富、安全可靠的替代方案,与商业云服务(如 Google Drive、Dropbox)相比提供更多控制和隐私保护。简单来…...

查看 SSD能承载的每秒随机IO次数

查看 SSD能承载的每秒随机IO次数 通常给大家的一个建议就是对于数据库部署的机器&#xff0c;一定要采用SSD固态硬盘&#xff0c;而不要使用机械 硬盘&#xff0c;因为SSD固态硬盘最强大的地方&#xff0c;就是他的随机IO性能非常高。 其次&#xff0c;光是用SSD还不够&#x…...

C# 设计模式(结构型模式):享元模式

C# 设计模式&#xff08;结构型模式&#xff09;&#xff1a;享元模式 (Flyweight Pattern) 在软件开发中&#xff0c;尤其是在处理大量对象时&#xff0c;我们常常会面临内存和性能上的挑战。当多个对象具有相似的状态时&#xff0c;通常会占用大量的内存资源&#xff0c;从而…...

使用Python,networkx构造有向图及无向图以及图合并等api

使用Python&#xff0c;networkx构造有向图及无向图以及图合并等api 源码图的构造、节点及边的添加等有向图及无向图及多重图 参考 方法名方法作用subgraph(G, nbunch)返回包含nbunch节点的子图union(G, H[, rename])合并G和H图disjoint_union(G, H)合并G和H图cartesian_produc…...

【SOC 芯片设计 DFT 学习专栏 -- 测试向量生成 ATPG (Automatic Test Pattern Generation) 】

文章目录 OverviewATPG 的基本功能ATPG 的工作流程ATPG 应用场景示例示例 1&#xff1a;检测单个信号的 Stuck-at Fault示例 2&#xff1a;针对 Transition Fault 的 ATPG ATPG 工具与常用工具链ATPG 优化与挑战 Overview 本文主要介绍 DFT scan 中的 ATPG 功能。在 DFT (Desi…...

uniapp本地加载腾讯X5浏览器内核插件

概述 TbsX5webviewUTS插件封装腾讯x5webview离线内核加载模块&#xff0c;可以把uniapp的浏览器内核直接替换成Android X5 Webview(腾讯TBS)最新内核&#xff0c;提高交互体验和流畅度。 功能说明 下载SDK插件 1.集成x5内核后哪些页面会由x5内核渲染&#xff1f; 所有plus…...

树莓派之旅-在wsl-x86-64 上进行树莓派的交叉编译

前情提要&#xff1a; 想把自己花里胡哨的终端丢到树莓派上去&#xff0c;可是树莓派算力不够&#xff0c;编译时间过于漫长 交叉编译 定义网上有&#xff0c;懒得复制了&#xff0c;大概就是在本机电脑上编译目标平台的可执行文件 这里的目标平台是树莓派 使用 uname -m …...

JavaScript中Map与Object的区别

在JavaScript中&#xff0c;Map和Object是用于存储键值对数据的两种不同的数据结构&#xff08;Map是ES6新增的数据结构&#xff09;&#xff0c;它们在构造方式、键的类型以及原型继承等方面存在区别。 一、主要区别 1.构造方式 Map&#xff1a;Map只能通过构造函数new Map…...

基于嵌入式无人机UAV通信系统的实时最优资源分配算法matlab仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 基于嵌入式无人机UAV通信系统的实时最优资源分配算法matlab仿真。具体参考文献&#xff1a; 考虑使用UAV作为中继辅助节点的设备到设备&#xff08;D2D&#xff09;无线信息和…...

计算机网络 (20)高速以太网

一、发展背景 随着计算机技术和网络应用的不断发展&#xff0c;传统的以太网速率已逐渐无法满足日益增长的带宽需求。因此&#xff0c;高速以太网应运而生&#xff0c;它以提高数据传输速率为主要目标&#xff0c;不断推动着以太网技术的发展。 二、技术特点 高速传输&#xff…...

element ui 组件 时间选择器出现转换问题的解决办法

在使用时间选择器添加数据是会出现转换失败问题 vue中代码为&#xff1a; 解决办法&#xff1a; 在el-date-picker中添加 format 和 value-format...

当知识图谱遇上文本智能处理,会擦出怎样的火花?

目前以理解人类语言为入口的认知智能成为了人工智能发展的突破点&#xff0c;而知识图谱则是迈向认知智能的关键要素。达观数据在2018AIIA人工智能开发者大会承办的语言认知智能与知识图谱公开课上&#xff0c;三位来自企业和学术领域的专家分别从不同角度讲述的知识图谱的应用…...

SpringBootWeb案例-1

文章目录 SpringBootWeb案例1. 准备工作1.1 需求&环境搭建1.1.1 需求说明1.1.2 环境搭建 1.2 开发规范 2. 部门管理2.1 查询部门2.1.1 原型和需求2.1.2 接口文档2.1.3 思路分析2.1.4 功能开发2.1.5 功能测试 2.2 前后端联调2.3 删除部门2.3.1 需求2.3.2 接口文档2.3.3 思路…...

在正则表达式中,\1 是用来引用第一个捕获组的内容的。捕获组是用括号 () 包裹的部分

在正则表达式中&#xff0c;\1 是用来引用第一个捕获组的内容的。捕获组是用括号 () 包裹的部分&#xff0c;它们会保存正则表达式匹配到的内容。在替换操作中&#xff0c;\1 就是对第一个捕获组内容的引用&#xff0c;表示你希望将捕获组中的内容放到替换文本中的某个位置。 …...

免费下载 | 2024年具身大模型关键技术与应用报告

这份报告的核心内容涉及具身智能的关键技术与应用&#xff0c;主要包括以下几个方面&#xff1a; 具身智能的定义与重要性&#xff1a; 具身智能是基于物理身体进行感知和行动的智能系统&#xff0c;通过与环境的交互获取信息、理解问题、做出决策并实现行动&#xff0c;产生智…...

[API测试] Karate 之独立运行方式

在 Karate 介绍与快速示例(API测试自动化、模拟、性能测试与UI自动化工具) 这一篇中介绍了如何在Maven项目中,如何结合JUnit 运行 Karate的API测试, 如果是专职的QA人员来测试, 对Java语言或者Maven完全不熟悉的话要怎么来运行 Karate的测试呢? 答案就是使用Karate的独立运…...

WeNet:面向生产的流式和非流式端到端语音识别工具包

这篇文章介绍了WeNet&#xff0c;一个面向生产的开源端到端&#xff08;E2E&#xff09;语音识别工具包。WeNet的主要特点和贡献如下&#xff1a; 统一流式和非流式识别&#xff1a;提出了一种名为U2的两阶段框架&#xff0c;能够在单一模型中同时支持流式和非流式语音识别&…...

《我在技术交流群算命》(二):QGraphicsItem怎么写自定义信号啊(QObject多继承顺序问题)

某位群友突然无征兆的抛出以下问题&#xff1a; QGraphicsItem怎么写自定义信号啊 看到这个问题的时候我是比较疑惑的&#xff0c;按鄙人对 Qt 的了解&#xff0c;自定义信号只需: 继承QObject类中加入Q_OBJECT宏声明一个信号并使用 但该群友毕竟也不是一个Qt新手&#xff0…...

实践深度学习:构建一个简单的图像分类器

引言 深度学习在图像识别领域取得了巨大的成功。本文将指导你如何使用深度学习框架来构建一个简单的图像分类器&#xff0c;我们将以Python和TensorFlow为例&#xff0c;展示从数据准备到模型训练的完整流程。 环境准备 在开始之前&#xff0c;请确保你的环境中安装了以下工…...

实践:事件循环

实践&#xff1a;事件循环 代码示例 console.log(1); setTimeout(() > console.log(2), 0); Promise.resolve(3).then(res > console.log(res)); console.log(4);上述的代码的输出结果是什么 1和4肯定优先输出&#xff0c;因为他们会立即方式堆栈的执行上下文中执行&am…...

基于Python的医院预约挂号与诊断系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…...

计算机网络基础

文章目录 名词含义1.应用层1.1网络应用原理1.1.1网络应用体系1.1.2进程通信1.1.3可供程序使用的运输服务1.1.4因特网的运输服务1.1.5应用层协议 1.2WEB和HTTP1.2.1HTTP概述1.2.2持续与非持续连接1.2.3报文格式 名词含义 ISP(Internet Service Provider&#xff0c;因特网服务提…...

Rabbitmq追问1

如果消费端代码异常&#xff0c;未手动确认&#xff0c;那么这个消息去哪里 2024-12-31 21:19:12 如果消费端代码发生异常&#xff0c;未手动确认&#xff08;ACK&#xff09;的情况下&#xff0c;消息的处理行为取决于消息队列的实现和配置&#xff0c;以下是基于 RabbitMQ …...

基于SpringBoot和OAuth2,实现通过Github授权登录应用

基于SpringBoot和OAuth2&#xff0c;实现通过Github授权登录应用 文章目录 基于SpringBoot和OAuth2&#xff0c;实现通过Github授权登录应用0. 引言1. 创建Github应用2. 创建SpringBoot测试项目2.1 初始化项目2.2 设置配置文件信息2.3 创建Controller层2.4 创建Html页面 3. 启动…...

python数据分析:使用pandas库读取和编辑Excel表

使用 Pandas&#xff0c;我们可以轻松地读取和写入Excel 文件&#xff0c;之前文章我们介绍了其他多种方法。 使用前确保已经安装pandas和 openpyxl库&#xff08;默认使用该库处理Excel文件&#xff09;。没有安装的可以使用pip命令安装&#xff1a; pip install pandas ope…...

SpringCloud源码分析-Lettue Redis

redis connection异步发送 底层是nio channel...

Linux(13)——网络概述

目录 一、TCP/IP 网络模型&#xff1a; 1、应用层&#xff08;Application&#xff09;&#xff1a; 2、传输层&#xff08;Transport&#xff09;&#xff1a; 3、互联网层&#xff08;Internet or network&#xff09;&#xff1a; 4、链路层&#xff08;Link&#xff0…...

PHP框架+gatewayworker实现在线1对1聊天--聊天界面布局+创建websocket连接(5)

文章目录 聊天界面布局html代码 创建websocket连接为什么要绑定&#xff1f; 聊天界面布局 在View/Index目录下创建index.html html代码 <div id"chat"><div id"nbar"><div class"pull-left">与牛德胜正在聊天...</div…...

Qos的详细解释

QoS&#xff08;Quality of Service&#xff09;&#xff0c;即服务质量&#xff0c;是一种用于网络管理的技术&#xff0c;旨在确保不同类型的数据流&#xff08;如语音、视频、文件传输等&#xff09;在网络中按优先级和要求得到适当的带宽、延迟、抖动和丢包率等服务&#x…...

未来20年在大语言模型相关研究方向--大语言模型的优化与改进

未来20年在大语言模型相关研究方向 模型性能优化 模型架构创新:研究新型的模型架构,如探索更高效的Transformer变体、融合递归神经网络(RNN)和卷积神经网络(CNN)的优点,以提高模型的性能、可扩展性和适应性,满足不同应用场景对模型效率和效果的要求。高效训练算法:开…...

【Vue】vue-router使用addRoute动态加载路由后刷新页面404

场景&#xff1a;动态加载路由&#xff0c;点击菜单路由跳转正常&#xff0c;但刷新页面报404 原因&#xff1a;使用404做异常路由捕获 刷新页面会导致路由丢失&#xff0c;重建路由时先加载了静态路由&#xff08;包含异常路由捕获404&#xff09;&#xff0c;此时动态路由还未…...

《计算机组成及汇编语言原理》阅读笔记:p177-p177

《计算机组成及汇编语言原理》学习第 13 天&#xff0c;p177-p177 总结&#xff0c;总计 1 页。 一、技术总结 1.real mode A programming model where the program has access to the entire capability of the machine, bypassing security and memory management. Useful…...

《从入门到精通:蓝桥杯编程大赛知识点全攻略》(一)-递归实现指数型枚举、递归实现排列型枚举

本篇博客将聚焦于通过递归来实现两种经典的枚举方法&#xff1a;指数型枚举和排列型枚举。这两种枚举方式在计算机科学和算法竞赛中都有广泛应用&#xff0c;无论是在解题中&#xff0c;还是在实际工作中都极具价值。 目录 前言 斐波那契数列递归 递归实现指数型枚举 算法思…...

游泳溺水识别数据集,对25729张图片进行YOLO,COCO JSON, VOC XML 格式的标注,溺水平均识别率在89.9%

游泳溺水识别数据集&#xff0c;对25729张图片进行YOLO&#xff0c;COCO JSON, VOC XML 格式的标注&#xff0c;溺水识别率在92&#xff05; 训练结果 数据集和标签 验证 游泳测试视频 根据测试的视频来获取检测结果&#xff1a; 游泳测试视频的置信度设置60% 检测结果如下&…...

coredns报错plugin/forward: no nameservers found

coredns报错plugin/forward: no nameservers found并且pod无法启动 出现该报错原因 是coredns获取不到宿主机配置的dns地址 查看宿主机是否有dns地址 resolvectl status 我这里是配置正确后&#xff0c;如果没配置过以下是不会显示出dns地址的 给宿主机增加静态dns地址之后将…...

【欢迎讨论方案一的可行性】SpringBoot集成netty,在handler中调用@Component注解的类

在Netty中处理请求时&#xff0c;调用一个由Spring Boot管理的Component注解的类 在Netty中处理请求时&#xff0c;调用一个由Spring Boot管理的Component注解的类&#xff0c;需要确保Spring上下文能够正确地注入这些组件。 方法一&#xff1a;使用Autowired注入Spring组件 …...

如何在LaTeX文档中为脚注添加横线,并调整横线的长度和厚度。

当然&#xff0c;以下是一个简单的例子&#xff0c;展示了如何在LaTeX文档中使用scrextend宏包来为脚注添加横线&#xff0c;并调整横线的长度和厚度。 ### 步骤1&#xff1a;导入scrextend宏包 在你的LaTeX文档的导言区&#xff08;\begin{document}之前的部分&#xff09;&…...

【C语言】可移植性陷阱与缺陷(三):整数的大小

目录 一、概述 二、整数类型的大小差异 三、 跨平台代码中的整数大小问题 3.1. 内存使用 3.2. 性能问题 3.3. 数据截断 3.4. 序列化/反序列化 四、解决整数大小问题的策略 4.1. 使用固定大小的整数类型 4.2. 条件编译 4.3. 避免假设 4.4. 文档化 五、总结 在C语言编…...

nginx基础篇 - 控制命令详解:启动/停止、配置文件检查/重新加载、nginx平滑升级

文章目录 1. nginx命令2 使用Unix工具发送信号3 常用操作3.1 检查配置文件3.2 启动nginx3.3 停止nginx3.4 重启nginx 4 平滑升级nginx 1. nginx命令 执行nginx -h命令可以看到所有的nginx命令及其解释&#xff1a; nginx命令使用方法: nginx [-?hvVtTq] [-s signal] [-p p…...

汽车驾校转型做无人机执照培训详解, “驾” 起无人机培训新未来?

汽车驾校转型做无人机执照培训&#xff0c;这一趋势确实在一定程度上预示着无人机培训领域的新未来。以下是对这一转型的详细分析&#xff1a; 一、转型背景 1. 无人机行业快速发展&#xff1a; 无人机技术在农业、影视、安防、物流等多个领域的应用不断拓展&#xff0c;市场…...

如何科学评估与选择新版本 Python 编程语言和工具

文章目录 摘要引言评估新版本的关键因素适用性评估成本与收益分析 新版本功能的实际应用示例代码模块详细解析示例代码模块代码模块解析实际应用场景如何运行与配图 QA环节总结参考资料 摘要 随着技术的快速发展&#xff0c;编程语言和软件工具不断推出新版本&#xff0c;带来…...