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

javascript实现一个函数,将字符串中的指定子串全部替换为另一个字符串的原理,以及多种方法实现。

大白话javascript实现一个函数,将字符串中的指定子串全部替换为另一个字符串的原理,以及多种方法实现。

在JavaScript里,要是你想把字符串里的指定子串都替换成另外一个字符串,有不少方法可以实现。下面我会详细介绍实现的原理,并且给出几种不同的实现方法。

原理

要把字符串里的指定子串全部替换成另一个字符串,核心思路就是找出所有的指定子串,然后用新的字符串把它们替换掉。在JavaScript里,有很多内置的方法能帮我们实现这个功能,像是replace方法、正则表达式等等。

方法一:使用replace方法结合正则表达式

replace方法可以替换字符串里的子串。不过默认情况下,它只替换第一个匹配到的子串。要是想替换所有匹配的子串,就得用正则表达式,并且加上g标志。

// 定义一个函数,接收三个参数:原始字符串、要替换的子串、替换后的字符串
function replaceAllWithRegex(str, search, replace) {// 使用正则表达式创建一个全局匹配的模式,这里的search是要查找的子串const regex = new RegExp(search, 'g');// 调用字符串的replace方法,传入正则表达式和替换后的字符串return str.replace(regex, replace);
}// 测试函数
const originalString = 'Hello, Hello, World!';
const newString = replaceAllWithRegex(originalString, 'Hello', 'Hi');
console.log(newString); // 输出: Hi, Hi, World!

方法二:使用splitjoin方法

我们可以先把字符串按照要替换的子串分割成数组,然后再用新的字符串把数组里的元素连接起来。

// 定义一个函数,接收三个参数:原始字符串、要替换的子串、替换后的字符串
function replaceAllWithSplitJoin(str, search, replace) {// 使用split方法将字符串按要替换的子串分割成数组const parts = str.split(search);// 使用join方法将数组元素用替换后的字符串连接起来return parts.join(replace);
}// 测试函数
const originalString2 = 'Hello, Hello, World!';
const newString2 = replaceAllWithSplitJoin(originalString2, 'Hello', 'Hi');
console.log(newString2); // 输出: Hi, Hi, World!

方法三:使用循环手动替换

我们还可以通过循环遍历字符串,手动找出要替换的子串,然后进行替换。

// 定义一个函数,接收三个参数:原始字符串、要替换的子串、替换后的字符串
function replaceAllManually(str, search, replace) {// 初始化一个空字符串,用于存储替换后的结果let result = '';// 初始化一个变量,用于记录当前查找的起始位置let index = 0;// 开始循环查找要替换的子串while (index < str.length) {// 查找当前位置开始的第一个匹配的子串const foundIndex = str.indexOf(search, index);if (foundIndex === -1) {// 如果没找到,把剩余的字符串添加到结果中result += str.slice(index);break;}// 把从当前位置到匹配子串之前的部分添加到结果中result += str.slice(index, foundIndex);// 把替换后的字符串添加到结果中result += replace;// 更新查找的起始位置,跳过已经替换的子串index = foundIndex + search.length;}// 返回替换后的结果return result;
}// 测试函数
const originalString3 = 'Hello, Hello, World!';
const newString3 = replaceAllManually(originalString3, 'Hello', 'Hi');
console.log(newString3); // 输出: Hi, Hi, World!

通过上面这几种方法,你就能在JavaScript里把字符串中的指定子串全部替换成另一个字符串了。不同的方法有不同的特点,你可以根据具体的需求来选择合适的方法。

解释一下replace方法的语法和参数。

在 JavaScript 里,replace 方法是字符串对象的一个内置方法,其用途是将字符串中的指定子串替换成另一个字符串。下面详细介绍它的语法和参数。

语法

str.replace(regexp|substr, newSubstr|function)

参数解释

第一个参数:regexp|substr

这个参数可以是正则表达式或者普通的字符串,具体如下:

  • 正则表达式(regexp:如果传入的是正则表达式,replace 方法就会在字符串中查找符合这个正则表达式规则的子串,然后进行替换操作。若正则表达式带有 g 标志(全局匹配),则会替换所有匹配到的子串;若没有 g 标志,就只会替换第一个匹配到的子串。

下面是使用正则表达式进行全局替换的示例:

const str = 'Hello, hello, world!';
// 创建一个全局匹配的正则表达式,用于匹配 'hello'(不区分大小写)
const regex = /hello/gi; 
const newStr = str.replace(regex, 'Hi');
console.log(newStr); // 输出: Hi, Hi, world!
  • 普通字符串(substr:若传入的是普通字符串,replace 方法只会替换字符串中第一个匹配到的该子串。

以下是使用普通字符串进行替换的示例:

const str = 'Hello, hello, world!';
const newStr = str.replace('hello', 'Hi');
console.log(newStr); // 输出: Hello, Hi, world!
第二个参数:newSubstr|function

这个参数可以是新的替换字符串,也可以是一个函数,具体如下:

  • 新的替换字符串(newSubstr:将匹配到的子串替换成这个新的字符串。在这个新字符串中,可以使用一些特殊的变量来引用匹配的内容,例如:
    • $&:表示匹配的子串。
    • `$``:表示匹配子串左边的部分。
    • $':表示匹配子串右边的部分。
    • $n:当第一个参数是正则表达式且包含捕获组时,$n 表示第 n 个捕获组的内容(n 是从 1 开始的数字)。

下面是使用特殊变量的示例:

const str = 'Hello, world!';
const newStr = str.replace('world', '$& and universe');
console.log(newStr); // 输出: Hello, world and universe!
  • 函数(function:若传入的是一个函数,每次匹配到子串时,都会调用这个函数,函数的返回值会作为替换的内容。函数可以接收多个参数,常见的参数有:
    • match:表示匹配到的子串。
    • p1, p2, ...:如果第一个参数是正则表达式且包含捕获组,这些参数表示对应的捕获组内容。
    • offset:表示匹配子串在原字符串中的起始位置。
    • string:表示原字符串。

以下是使用函数进行替换的示例:

const str = 'Hello, world!';
const newStr = str.replace('world', function(match) {return match.toUpperCase();
});
console.log(newStr); // 输出: Hello, WORLD!

返回值

replace 方法会返回一个新的字符串,该字符串是原字符串经过替换操作后的结果,原字符串本身不会被修改。

如何使用replace方法实现不区分大小写的替换?

在 JavaScript 中,若要使用 replace 方法实现不区分大小写的替换,可借助正则表达式并添加 i 标志来达成。i 标志的作用是让正则表达式在匹配时忽略大小写。以下为你展示具体的实现方式与示例代码:

示例代码

// 定义一个包含目标子串的原始字符串
const originalString = 'Hello, hello, WORLD!';
// 定义要查找的子串,这里以 'hello' 为例
const searchString = 'hello';
// 定义用于替换的新字符串
const replacementString = 'Hi';// 创建一个不区分大小写的正则表达式,使用 new RegExp 动态创建
const regex = new RegExp(searchString, 'gi');
// 使用 replace 方法结合正则表达式进行不区分大小写的替换
const newString = originalString.replace(regex, replacementString);// 输出替换后的新字符串
console.log(newString); 

代码解释

  1. 创建正则表达式:借助 new RegExp(searchString, 'gi') 构建一个不区分大小写的全局匹配正则表达式。其中,searchString 是要查找的子串,'g' 标志表示全局匹配(即替换所有匹配项),'i' 标志表示忽略大小写。
  2. 使用 replace 方法:调用 originalString.replace(regex, replacementString) 方法,把 originalString 里所有匹配 regex 的子串替换成 replacementString
  3. 输出结果:最后将替换后的新字符串输出。

直接在 replace 方法中使用正则表达式字面量

如果你要查找的子串是固定的,也可以直接在 replace 方法中使用正则表达式字面量,示例如下:

const originalString = 'Hello, hello, WORLD!';
const newString = originalString.replace(/hello/gi, 'Hi');
console.log(newString); 

上述代码中,/hello/gi 是一个正则表达式字面量,同样表示不区分大小写的全局匹配。这种方式适合查找子串固定的情况。

相关文章:

javascript实现一个函数,将字符串中的指定子串全部替换为另一个字符串的原理,以及多种方法实现。

大白话javascript实现一个函数&#xff0c;将字符串中的指定子串全部替换为另一个字符串的原理&#xff0c;以及多种方法实现。 在JavaScript里&#xff0c;要是你想把字符串里的指定子串都替换成另外一个字符串&#xff0c;有不少方法可以实现。下面我会详细介绍实现的原理&a…...

Python 3 与 MySQL 数据库连接:mysql-connector 模块详解

Python 3 与 MySQL 数据库连接&#xff1a;mysql-connector 模块详解 概述 在Python 3中&#xff0c;与MySQL数据库进行交互是一个常见的需求。mysql-connector是一个流行的Python模块&#xff0c;它提供了与MySQL数据库连接和交互的接口。本文将详细介绍mysql-connector模块…...

HCIA-Datacom高阶:基础的单区域 OSPF 与多区域 OSPF的配置

动态路由协议是实现网络高效通信的关键技术之一。开放式最短路径优先&#xff08;Open Shortest Path First&#xff0c;OSPF&#xff09;协议作为内部网关协议&#xff08;IGP&#xff09;的一种&#xff0c;因其高效性、稳定性和扩展性&#xff0c;在大型网络中得到了广泛应用…...

蓝桥杯单片机刷题——E2PROM记录开机次数

设计要求 使用E2PROM完成数据记录功能&#xff0c;单片机复位次数记录到E2PROM的地址0中。每复位一次数值加1&#xff0c;按下按键S4&#xff0c;串口发送复位次数。串口发送格式如下&#xff1a; Number&#xff1a;1 备注&#xff1a; 单片机IRC振荡器频率设置为12MHz。 …...

杂草YOLO系列数据集4000张

一份开源数据集——杂草YOLO数据集&#xff0c;该数据集适用于农业智能化、植物识别等计算机视觉应用场景。 数据集详情 ​训练集&#xff1a;3,664张高清标注图像​测试集&#xff1a;180张多样性场景样本​验证集&#xff1a;359张严格筛选数据 下载链接 杂草YOLO数据集分…...

Python自动化面试通关秘籍

Python自动化测试工程师面试&#xff0c;不仅仅是考察你的代码能力&#xff0c;更看重你如何在项目中灵活运用工具和框架解决实际问题。如果你正准备面试&#xff0c;这篇文章将为你总结最常见的高频考题及答题技巧&#xff0c;帮助你快速上手&#xff0c;通关面试&#xff0c;…...

机器学习的一百个概念(1)单位归一化

前言 本文隶属于专栏《机器学习的一百个概念》&#xff0c;该专栏为笔者原创&#xff0c;引用请注明来源&#xff0c;不足和错误之处请在评论区帮忙指出&#xff0c;谢谢&#xff01; 本专栏目录结构和参考文献请见[《机器学习的一百个概念》 ima 知识库 知识库广场搜索&…...

Python 笔记 (二)

Python Note 2 1. Python 慢的原因2. 三个元素3. 标准数据类型4. 字符串5. 比较大小: 富比较方法 rich comparison6. 数据容器 (支持*混装* )一、允许重复类 (list、tuple、str)二、不允许重复类 (set、dict)1、集合(set)2、字典(dict)3、特殊: 双端队列 deque 三、数据容器的共…...

【商城实战(97)】ELK日志管理系统的全面应用

【商城实战】专栏重磅来袭!这是一份专为开发者与电商从业者打造的超详细指南。从项目基础搭建,运用 uniapp、Element Plus、SpringBoot 搭建商城框架,到用户、商品、订单等核心模块开发,再到性能优化、安全加固、多端适配,乃至运营推广策略,102 章内容层层递进。无论是想…...

3.使用epoll实现单线程并发服务器

目录 1. epoll的概述 2. 多线程与epoll的处理流程 2.1 多线程处理流程 2.2 epoll处理流程 3. epoll与多线程的比较 4. epoll的操作函数 4.1 epoll_create() 4.2 epoll_ctl() 4.3 epoll_wait() 5. 示例代码 6. epoll的工作模式 7. 使用O_NONBLOCK防止阻塞 8.运行代…...

蓝桥杯真题------R格式(高精度乘法,高精度加法)

对于高精度乘法和加法的同学可以学学这几个题 高精度乘法 高精度加法 文章目录 题意分析部分解全解 后言 题意 给出一个整数和一个浮点数&#xff0c;求2的整数次幂和这个浮点数相乘的结果最后四舍五入。、 分析 我们可以发现&#xff0c;n的范围是1000,2的1000次方非常大&am…...

PyCharm操作基础指南

一、安装与配置 1. 版本选择 专业版&#xff1a;支持 Web 开发&#xff08;Django/Flask&#xff09;、数据库工具、科学计算等&#xff08;需付费&#xff09;。 社区版&#xff1a;免费&#xff0c;适合纯 Python 开发。 2. 安装步骤 访问 JetBrains 官网 下载对应版本。…...

21 python __name__ 与 __main__

在办公室里&#xff0c;每个员工都有自己的工牌&#xff0c;上面写着姓名和部门。 一、__name__&#xff1a;模块的名字 Python 模块也有类似的 "工牌"——__name__属性&#xff0c;它记录了模块的身份&#xff1a; 直接运行时 → __name__ "__main__"&…...

NixVis 开源轻量级 Nginx 日志分析工具

NixVis NixVis 是一款基于 Go 语言开发的、开源轻量级 Nginx 日志分析工具&#xff0c;专为自部署场景设计。它提供直观的数据可视化和全面的统计分析功能&#xff0c;帮助您实时监控网站流量、访问来源和地理分布等关键指标&#xff0c;无需复杂配置即可快速部署使用。 演示…...

elementUI el-image图片加载失败解决

是不是&#xff0c;在网上找了一些&#xff0c;都不行&#xff0c;这里一行代码&#xff0c;解决&#xff0c;后端返回图片路径&#xff0c;el-image图片加载失败的问题 解决办法&#xff0c; vue项目里&#xff0c;index.html文件里加一行代码就可 <meta name"refe…...

lxd-dashboard 图形管理LXD/LXC

前言 LXD-WEBGUI是一个完全用AngularJS编写的Web应用程序,无需应用服务器、数据库或其他后端服务支持。只需要简单地托管静态HTML和JavaScript文件,就能立即投入使用。这个项目目前处于测试阶段,提供了直观的用户界面,帮助用户便捷地管理和控制LXD实例。 安装lxd-dashboa…...

C# MemoryStream 使用详解

总目录 前言 在.NET开发中&#xff0c;流&#xff08;Stream&#xff09;是一个用于处理输入和输出的抽象类&#xff0c;MemoryStream是流的一个具体实现&#xff0c;它允许我们在内存中读写数据&#xff0c;就像操作文件一样&#xff0c;而无需涉及磁盘 I/O 操作。尤其适合需…...

(二)万字长文解析:deepResearch如何用更长的思考时间换取更高质量的回复?各家产品对比深度详解

DeepResearch的研究背景 业务背景&#xff1a;用更长的等待时间&#xff0c;换取更高质量、更具实用性的结果 当前AI技术发展正经历从“即时响应”到“深度思考”的范式转变。用户对延迟的容忍度显著提升&#xff0c;从传统200ms的交互响应放宽至数秒甚至数分钟&#xff0c;以…...

Redis场景问题1:缓存穿透

Redis 缓存穿透是指在缓存系统&#xff08;如 Redis&#xff09;中&#xff0c;当客户端请求的数据既不在缓存中&#xff0c;也不在数据库中时&#xff0c;每次请求都会直接穿透缓存访问数据库&#xff0c;从而给数据库带来巨大压力&#xff0c;甚至可能导致数据库崩溃。下面为…...

数据结构(并查集,图)

并查集 练习版 class UnionFindSet { public:void swap(int* a, int* b){int tmp *a;*a *b;*b tmp;}UnionFindSet(size_t size):_ufs(size,-1){}int UnionFind(int x){}void Union(int x1, int x2){}//长分支改为相同节点int FindRoot(int x){}bool InSet(int x1, int x2)…...

深度学习篇---断点重训模型部署文件

文章目录 前言一、断点重训&#xff08;Checkpoint&#xff09;文件1. 动态图&#xff08;DyGraph&#xff09;模式.pdparams 文件.pdopt 文件.pdscaler 文件.pdmeta 或 .pkl 文件 2. 静态图&#xff08;Static Graph&#xff09;模式.pdparams 和 .pdopt 文件.ckpt 文件 3. 恢…...

chromem-go + ollama + bge-m3 进行文档向量嵌入和查询

Ollama 安装 https://ollama.com/download Ollama 运行嵌入模型 bge-m3:latest ollama run bge-m3:latestchromem-go 文档嵌入和查询 package mainimport ("context""fmt""runtime""github.com/philippgille/chromem-go" )func ma…...

运维面试题(十一)

1.如果一个硬盘 IO 时阻塞了&#xff0c;会发生什么情况&#xff1f; 进程/线程挂起&#xff1a;发起I/O操作的进程或线程会被操作系统置为阻塞状态&#xff08;等待状态&#xff09;&#xff0c;直到I/O完成。CPU资源释放&#xff1a;阻塞的线程会让出CPU&#xff0c;操作系统…...

深度学习中常见的专业术语汇总

本硕博都是搞机械的匠人&#xff0c;当然也想做一下交叉学科的东西&#xff0c;蹭一下人工智能的热点。虽然世界是个草台班子&#xff0c;但是来都来了&#xff0c;咱也要把这场戏演好。 记得之前网上爆料有位大学生发了很多水文&#xff0c;对&#xff0c;是交叉学科的&#x…...

人工智能赋能医疗:开启智慧医疗新时代

在当今数字化浪潮的推动下&#xff0c;人工智能&#xff08;AI&#xff09;技术正以前所未有的速度渗透到各个行业&#xff0c;其中医疗领域更是成为AI技术大放异彩的重要舞台。从疾病诊断到治疗方案制定&#xff0c;从医疗影像分析到药物研发&#xff0c;AI正在为传统医疗带来…...

stable diffusion 本地部署教程 2025最新版

前提&#xff1a; 需要环境 git git下载地址Git - Downloading Package ​ 直接装即可 python3.10.6 下载地址 Python Release Python 3.10.6 | Python.org ​ 记得python环境一定要3.10.6&#xff01;&#xff01;&#xff01; 第一个版本 项目地址https://github.…...

[Mac]利用Hexo+Github Pages搭建个人博客

由于我这台Mac基本没啥环境&#xff0c;因此需要从零开始配置&#xff0c;供各位参考。 注意⚠️&#xff1a;MacBook (M4)使用/bin/zsh作为默认Shell&#xff0c;其对应的配置文件为~/.zshrc 参考文档&#xff1a; HEXO系列教程 | 使用GitHub部署静态博客HEXO | 小白向教程 文…...

罗杰斯特回归

定义 逻辑回归其实就是原来的线性回归加了激活函数&#xff0c;这个函数其实就是sigmoid函数&#xff0c;把一个回归的连续数值压缩到了0到1的空间&#xff0c;其实只要有函数能够满足把数值压缩到0,1之间就可以&#xff08;因为0到1之间的数值就是概率值&#xff09; 对于分类…...

27_promise

插入一下前端助手测试&#xff0c;顺手可以用来做安全 promise promise 是一个es6新增的语法 汉语&#xff1a;承诺的意思 作用:是专门用来解决回调地狱!!!! 什么是回调函数&#xff1f; <script>// 回调函数 callback回调// 就是把函数A当作参数传递到函数B中// 在函…...

【机械视觉】C#+VisionPro联合编程———【六、visionPro连接工业相机设备】

【机械视觉】C#VisionPro联合编程———【六、visionPro连接工业相机设备】 目录 【机械视觉】C#VisionPro联合编程———【六、visionPro连接工业相机设备】 前言&#xff1a; 连接步骤说明 一. 硬件连接 支持的相机接口类型&#xff1a; 连接步骤 2. 软件配置 Visio…...

红宝书第十九讲:详解JavaScript的Fetch API与Ajax请求

红宝书第十九讲&#xff1a;详解JavaScript的Fetch API与Ajax请求 资料取自《JavaScript高级程序设计&#xff08;第5版&#xff09;》。 查看总目录&#xff1a;红宝书学习大纲 一、基本概念&#xff1a;为什么需要Fetch&#xff1f; Fetch API是浏览器提供的现代网络请求工…...

【深度学习新浪潮】具身智能及其发展前景分析

一、具身智能的定义 具身智能(Embodied Intelligence) 是指通过物理载体(如机器人)与环境实时交互,实现感知、决策与行动闭环的智能系统。其核心在于将人工智能与物理实体结合,强调“智能源于身体与环境的互动”,而非仅依赖虚拟算法。具身智能的典型特征包括多模态感知…...

练习题:111

目录 Python题目 题目 题目分析 需求理解 关键知识点 实现思路分析 代码实现 代码解释 指定文件路径和名称&#xff1a; 定义要写入的内容&#xff1a; 打开文件并写入内容&#xff1a; 异常处理&#xff1a; 输出提示信息&#xff1a; 运行思路 结束语 Python题…...

第三次作业

1、将你的虚拟机的网卡模式设置为nat模式&#xff0c;给虚拟机网卡配置三个主机位分别为100、200、168的ip地址 首先将虚拟机在vmware编辑里将网卡模式改为nat 然后用nmcli c mod ens160 ipv4.addresses 192.168.254.100 nmcli c mod ens160 ipv4.addresses 192.168.254.200…...

Oracle数据库数据编程SQL<3.1 PL/SQL 匿名块 及 流程控制中的条件判断、循环、异常处理和随机函数应用>

PL/SQL部分 在SQL的基础上增加了一些过程化的控制语句。 过程化控制语句包括&#xff1a;类型定义、判断、循环、游标、异常处理&#xff08;例外处理&#xff09; 目录 PL/SQL匿名块 一、匿名块基本结构 1、匿名块由三个部分组成&#xff1a; 2、注意事项&#xff1a; …...

CEF 给交互函数, 添加控制台是否显示交互参数log开关

CEF 控制台添加一函数,枚举 注册的供前端使用的CPP交互函数有哪些 CEF 多进程模式时,注入函数,获得交互信息-CSDN博客 这两篇文章,介绍了注入函数,在控制台中显示 各自提供的交互函数信息。 有些场景下,我们还需要更详细的信息,比如想知道 彼此传递的参数, 如果每次调…...

如何用 Postman 正确传递 Date 类型参数,避免服务器解析错误?

如何在 Postman 中传递 Date 类型参数。调试工具如何模拟发送用户端的当前时间呢&#xff1f; Postman 传递 Date 类型参数教程...

从代码学习深度学习 - 含并行连结的网络(GoogLeNet)PyTorch版

文章目录 前言一、GoogLeNet的理论基础1.1 背景与创新点1.2. Inception模块的工作原理二、完整代码实现与解析2.1. 环境准备与工具函数2.2. 数据加载 - Fashion-MNIST2.3. Inception模块设计2.4. GoogLeNet完整模型2.5. 训练函数2.6. 运行训练三、训练结果与分析3.1. 性能分析3…...

进程Kill杀死后GPU显存没有释放仍然被占用,怎么杀死僵尸进程

参考链接&#xff1a; https://blog.csdn.net/qq_37591986/article/details/131118109 使用下面的命令&#xff1a; fuser -v /dev/nvidia0 | awk {print $0} | xargs kill -9一般来说他会杀掉整个用户的所有进程。...

Deepseek API+Python 测试用例一键生成与导出 V1.0.3

** 功能详解** 随着软件测试复杂度的不断提升,测试工程师需要更高效的方法来设计高覆盖率的测试用例。Deepseek API+Python 测试用例生成工具在 V1.0.3 版本中,新增了多个功能点,优化了提示词模板,并增强了对文档和接口测试用例的支持,极大提升了测试用例设计的智能化和易…...

【字符设备驱动开发–IMX6ULL】(一)简介

【字符设备驱动开发–IMX6ULL】&#xff08;一&#xff09;简介 一、Linux驱动与裸机开发区别 1.裸机驱动开发回顾 ​ 1、底层&#xff0c;跟寄存器打交道&#xff0c;有些MCU提供了库。 spi.c&#xff1a;主机驱动&#xff08;换成任何一个设备之后只需要调用此文件里面的…...

MaxKB 如何通过Nginx修改浮框提示文字

在使用MaxKB做第三方嵌入的时候&#xff0c;总会有想Diy前端样式的场景&#xff0c;下面就通过Nginx的方式&#xff0c;实现浮框样式的改变。 一、效果对比 修改前&#xff1a; 修改后&#xff1a; 前后对比&#xff1a; 修改了提示文字。去掉了图标后面的白框 下面讲一下该…...

中小型企业网络的搭建

1.1 网络逻辑拓扑、布线方案的设计 1.1.1 网络设计依据 网络设计应遵循以下基本原则&#xff1a; 高效性&#xff1a;确保网络架构能够支持企业日常业务的高效运行。 可靠性&#xff1a;采用冗余设计&#xff0c;确保网络的高可用性&#xff0c;避免单点故障。 可扩展性…...

第二卷:海盐城血战(37-72回)正反人物群像

第二卷&#xff1a;海盐城血战&#xff08;37-72回&#xff09;正反人物群像 核心矛盾&#xff1a;寒门军事崛起 → 内部倾轧 → 制度性腐败 主题&#xff1a;通过人物群像展现寒门胜利的虚幻性与权力异化的必然性 一、正派阵营&#xff08;寒门抗争势力&#xff09; 1. 刘裕…...

qt之使用redis与其他程序(python)交互同通信

一、前言 有需求&#xff0c;趁热调试出了嵌入式系统的算法环境安装和远程桌面以及一些其他的之前一直未调试出搁置的功能&#xff0c;趁热继续调试进阶功能redis通信&#xff0c;redis与sqlite各有千秋&#xff0c;redis可以作为在嵌入式系统下多个程序之间相互通信的中间件&…...

Pycharm(七):几个简单案例

一.剪刀石头布 需求&#xff1a;和电脑玩剪刀石头布游戏 考察点&#xff1a;1.随机数&#xff1b;2.判断语句 import random # numrandom.randint(1,3) # print(num) # print(**30) #1.录入玩家手势 playerint(input(请输入手势&#xff1a;&#xff08;1.剪刀 2.石头 3&…...

05.AI搭建preparationの(transformers01)BertTokenizer实现分词编码

一、下载 bert-base-chinese镜像下载 二、简介作用&#xff1a; 模型每个参数占用的字节大小模型大小模型大小层数头数GPT-14 个字节的 FP32 精度浮点数117M446MB1212GPT-22 个字节的 FP161.5亿到1.75亿0.5GB到1.5GB4816GPT-32 个字节的 FP161.75万亿&#xff08;17500亿&a…...

Perl 环境安装指南

Perl 环境安装指南 引言 Perl是一种广泛使用的解释型、动态编程语言,以其强大的文本处理能力和灵活性著称。本文将为您详细介绍Perl环境的安装过程,包括系统要求、安装步骤以及注意事项。 系统要求 在安装Perl之前,请确保您的计算机满足以下基本要求: 操作系统:Window…...

Visual Studio中创建和配置设置文件(Settings.settings) - 详细步骤指南——待调试

#在Visual Studio中创建和配置设置文件(Settings.settings) - 详细步骤指南 在Visual Studio中创建和配置应用程序设置文件&#xff0c;用于保存用户上次输入的值。 第一步&#xff1a;添加设置文件 1. **打开你的项目**&#xff1a;在Visual Studio中打开你的AutoCAD插件项目 …...

Nginx的时钟精度陷阱:request_time与upstream_response_time差异分析

在elasticsearch 采集nginx日志分析的场景下发现&#xff0c; request_time 小于upstream_response_time &#xff0c;于是才有了这边文章。 在 Nginx 中&#xff0c;upstream_response_time 和 request_time 使用不同的系统时钟和精度机制来记录时间&#xff0c;这可能导致 u…...