C#中实现JSON解析器
JSON(JavaScript Object Notation)即 JavaScript 对象表示法,是一种轻量级的数据交换格式。
起源与发展
JSON 源于 JavaScript 编程语言,是 JavaScript 对象字面量语法的一个子集。但如今它已经独立于 JavaScript,成为一种通用的数据格式,广泛应用于各种编程语言和系统之间的数据交换。由于其简洁性和通用性,在 Web 开发、移动应用开发、云计算等领域得到了极为广泛的应用。
特点
轻量级:相较于 XML 等其他数据交换格式,JSON 的数据结构更加简洁,文件体积更小,这使得在网络传输过程中能够减少带宽占用,提高传输效率。
易读性:JSON 的文本格式清晰、简洁,符合人类的阅读习惯,开发人员可以很容易地理解和解析其中的数据内容。
跨语言兼容性:几乎所有的现代编程语言都提供了对 JSON 的支持,能够方便地将 JSON 数据解析为本地数据结构,或者将本地数据结构转换为 JSON 格式,这使得不同编程语言开发的系统之间能够轻松进行数据交换。
实现思路:
词法分析
词法分析的目的是将输入的 JSON 字符串分解为一个个的词法单元,例如花括号、方括号、逗号、冒号、字符串、数字、布尔值和空值等。我们可以定义一个 Token 类来表示词法单元,以及一个 Tokenizer 类来进行词法分析。
语法分析
语法分析的目的是根据词法单元构建 JSON 对象或数组。我们可以定义一个 JsonParser 类来进行语法分析,它将接收一个 Tokenizer 对象作为输入,并返回解析后的 JSON 对象或数组。
代码实现:
1.定义Token类:
public enum TokenType
{STRING,NUMBER,BOOLEAN,NULL,LEFT_BRACE,RIGHT_BRACE,LEFT_BRACKET,RIGHT_BRACKET,COMMA,COLON,EOF
}public class Token
{public TokenType Type { get; }public object Value { get; }public Token(TokenType type, object value){Type = type;Value = value;}
}
2.实现扫描类:
public class Scanner
{private readonly string source;private int start;private int current;private int line = 1;private readonly List<Token> tokens = new List<Token>();public Scanner(string source){this.source = source;}public List<Token> Scan(){while (!IsAtEnd()){start = current;ScanToken();}tokens.Add(new Token(TokenType.EOF, null));return tokens;}private bool IsAtEnd() => current >= source.Length;private void ScanToken(){char c = Advance();switch (c){case '{':AddToken(TokenType.LEFT_BRACE, c);break;case '}':AddToken(TokenType.RIGHT_BRACE, c);break;case '[':AddToken(TokenType.LEFT_BRACKET, c);break;case ']':AddToken(TokenType.RIGHT_BRACKET, c);break;case ',':AddToken(TokenType.COMMA, c);break;case ':':AddToken(TokenType.COLON, c);break;case '\n':line++;break;case ' ':break;case '"':AddString();break;case '-':if (char.IsDigit(Peek())){Advance();AddNumber();}else{throw new ArgumentException($"'-' must be followed by a digit at line {line}");}break;default:if (char.IsDigit(c)){AddNumber();}else if (char.IsLetter(c)){AddKeyword();}else{throw new ArgumentException($"Unexpected character '{c}' at line {line}");}break;}}private void AddToken(TokenType type, char character){tokens.Add(new Token(type, character.ToString()));}private char Advance() => source[current++];private void AddString(){while (Peek() != '"' && !IsAtEnd()){if (Peek() == '\n') line++;Advance();}if (IsAtEnd())throw new ArgumentException($"Unterminated string at line {line}");Advance(); // Consume closing '"'int startIndex = start + 1;int length = current - start - 2;string value = source.Substring(startIndex, length);tokens.Add(new Token(TokenType.STRING, value));}private void AddNumber(){while (char.IsDigit(Peek())) Advance();if (Peek() == '.' && char.IsDigit(PeekNext())){Advance(); // Consume '.'while (char.IsDigit(Peek())) Advance();ParseNumber(true);}else{ParseNumber(false);}}private void ParseNumber(bool isDouble){string numberStr = source.Substring(start, current - start);if (isDouble){if (double.TryParse(numberStr, out double result))tokens.Add(new Token(TokenType.NUMBER, result));elsethrow new ArgumentException($"Invalid float format '{numberStr}' at line {line}");}else{if (int.TryParse(numberStr, out int result))tokens.Add(new Token(TokenType.NUMBER, result));elsethrow new ArgumentException($"Invalid integer format '{numberStr}' at line {line}");}}private char Peek() => IsAtEnd() ? '\0' : source[current];private char PeekNext() => (current + 1 >= source.Length) ? '\0' : source[current + 1];private void AddKeyword(){while (char.IsLetter(Peek())) Advance();string keyword = source.Substring(start, current - start);switch (keyword){case "true":tokens.Add(new Token(TokenType.BOOLEAN, true));break;case "false":tokens.Add(new Token(TokenType.BOOLEAN, false));break;case "null":tokens.Add(new Token(TokenType.NULL, null));break;default:throw new ArgumentException($"Unexpected keyword '{keyword}' at line {line}");}}
}
3.实现解析类:
public class Parser
{private readonly List<Token> tokens;private int current;public Parser(List<Token> tokens){this.tokens = tokens;current = 0;}public object Parse(){Token token = Advance();return ParseFromToken(token);}private object ParseFromToken(Token token){switch (token.Type){case TokenType.STRING:case TokenType.NUMBER:case TokenType.BOOLEAN:case TokenType.NULL:return token.Value;case TokenType.LEFT_BRACE:return ParseObject();case TokenType.LEFT_BRACKET:return ParseArray();default:throw new ArgumentException($"Unexpected token type: {token.Type}", nameof(token));}}private Dictionary<string, object> ParseObject(){var jsonObject = new Dictionary<string, object>();Token keyToken = Advance();while (keyToken.Type != TokenType.RIGHT_BRACE){if (keyToken.Type == TokenType.EOF)throw new ArgumentException("Unterminated JSON object");if (keyToken.Type != TokenType.STRING)throw new ArgumentException("JSON object fields must begin with a string key");Consume(TokenType.COLON, "Key-value pairs must be separated by colon");Token valueToken = Advance();jsonObject[(string)keyToken.Value] = ParseFromToken(valueToken);ConsumeCommaUnless(TokenType.RIGHT_BRACE);keyToken = Advance();}return jsonObject;}private List<object> ParseArray(){var jsonArray = new List<object>();Token token = Advance();while (token.Type != TokenType.RIGHT_BRACKET){if (token.Type == TokenType.EOF)throw new ArgumentException("Unterminated JSON array");jsonArray.Add(ParseFromToken(token));ConsumeCommaUnless(TokenType.RIGHT_BRACKET);token = Advance();}return jsonArray;}private Token Advance(){if (current >= tokens.Count)throw new IndexOutOfRangeException("Unexpected end of token stream");return tokens[current++];}private void Consume(TokenType expectedType, string errorMessage){if (Peek().Type != expectedType)throw new ArgumentException($"{errorMessage}. Expected: {expectedType}, Actual: {Peek().Type}");current++;}private void ConsumeCommaUnless(TokenType exceptionType){if (Peek().Type == TokenType.COMMA){current++;return;}if (Peek().Type != exceptionType)throw new ArgumentException($"Missing comma before token: {Peek().Type}");}private Token Peek(){if (current >= tokens.Count)return new Token(TokenType.EOF, null);return tokens[current];}
}
4.测试类:
public class JsonParser : MonoBehaviour
{string jsonString1= @"{""name"": ""张三"",""age"": 28,""is_student"": false,""hobbies"": [""阅读"", ""游泳""],""address"": {""street"": ""人民路123号"",""city"": ""北京""}}";void Start(){var scanner = new Scanner(jsonString1);List<Token> tokens = scanner.Scan();var parser = new Parser(tokens);object parsed = parser.Parse();this.TranslateJsonObj(parsed);}void TranslateJsonObj(object result){switch (result){case Dictionary<string, object> obj:HandleObject(obj);break;case List<object> arr:HandleArray(arr);break;case string s:Debug.Log($"字符串值: {s}");break;case double d:Debug.Log($"数字值: {d}");break;case bool b:Debug.Log($"布尔值: {b}");break;case null:Debug.Log("空值");break;}}void HandleObject(Dictionary<string, object> obj){string typeName = "";foreach (var item in obj){typeName = item.Value.GetType().Name;if (typeName.Contains("List`1") || typeName.Contains("Dictionary`2")){Debug.Log($"Key: {item.Key}");TranslateJsonObj(item.Value);}else{Debug.Log($"Key: {item.Key} Value: {item.Value}");}}}void HandleArray(List<object> arr){foreach (var item in arr){Debug.Log($"object: {item}");}}
}
结果:
参考链接:
Implement a JSON parser from scratch in 10 minutes (Python) (youtube.com)
Build Your Own JSON Parser | codingchallenges.fyi (youtube.com)
JSON Parser in C | Lexer (youtube.com)
Let's Build a Superfast JSON Parser from scratch in C# - Part 1 The Lexer (youtube.com)
Let's Build a Superfast JSON Parser from scratch in C# Part 2 The Parser and Deserialization (youtube.com)
JSON - 维基百科,自由的百科全书 (wikipedia.org)
相关文章:
C#中实现JSON解析器
JSON(JavaScript Object Notation)即 JavaScript 对象表示法,是一种轻量级的数据交换格式。 起源与发展 JSON 源于 JavaScript 编程语言,是 JavaScript 对象字面量语法的一个子集。但如今它已经独立于 JavaScript,成…...
Android studio进阶开发(四)--okhttp的网络通信的使用
我们之前学过了socket服务器,这次我们继续来学习网络热门编程http/https的使用与交互 1)什么是Http协议? 答:hypertext transfer protocol(超文本传输协议),TCP/IP协议的一个应用层协议&#x…...
untiy 实现点击按钮切换天空盒子
1.新建材质DaySkybox和NightSkybox 设置 Shader 为 Skybox/6 Sided 2.创建ui 切换按钮,编写天空 盒子的脚本 using UnityEngine; using UnityEngine.UI;public class SkyboxSwitcher : MonoBehaviour {public Material daySkybox; // 拖入白天的天空盒材质publi…...
Docker从0-1搭建个人云盘(支持Android iOS PC)
一、Docker位置配置【遇到再大的事,先备份MYSQL数据库,说了多少遍】 ******************************************************************************************************************************************* docker rm -f $(docker ps -a -q…...
Java Agent 注入 WebSocket 篇
Agent 如果要对其进行Agent注入的编写,需要先理解三个名字premain,agentmain,Instrumentation premain方法在 JVM 启动阶段调用,一般维持权限的时候不会使用 agentmain方法在 JVM 运行时调用 常用的 Instrumentation实例为代理…...
Linux:git和gdb/cgdb
一:在XShell上使用git 步骤1:安装git命令行 sudo yum install git 步骤2:注册git账户和仓库,并点击克隆/下载,把HTTPS复制 步骤3: 在显示屏上输入下面命令,然后按提示输入自己的用户名和邮箱…...
深度对比评测:n8n vs Coze(扣子) vs Dify - 自动化工作流工具全解析
引言 在当今数字化转型的浪潮中,自动化工作流工具已成为企业和个人提升效率的关键利器。n8n、Coze(扣子)和Dify作为三款各具特色的自动化工具,在开发者社区和商业用户中都引起了广泛关注。本文将为您带来这三款工具的深度对比评测…...
如何用国产CAD软件皇冠CAD(CrownCAD)三维建模“橡胶座椅”?
皇冠CAD(CrownCAD)以『橡胶座椅』为例讲解“曲面设计、填充曲面、投影曲线、扫描曲面、放样曲面”等三维CAD操作技巧。 在现有模型边线、草图或曲面所定义的边框内填充一曲面。 点击进入填充曲面命令,其界面如下图所示: 各界面参…...
Whisper微调及制作方言数据集
本文不生产技术,只做技术的搬运工!!! 前言 最近在进行whisper微调实验,这个网上有很多成功案例,作者随机找了一个进行了复现,但是由于微调目的是适配本地方言,数据集的采集成为了一…...
实现营销投放全流程自动化 超级汇川推出信息流智能投放产品“AI智投“
随着消费者行为模式的多样化和媒体渠道的日益分散,数字营销行业面临挑战。传统人工数据分析效率低、误差率高,大幅制约广告预算效能。针对上述痛点,近期阿里巴巴旗下超级汇川广告平台推出“AI智投”信息流智能投放产品,基于AI大模…...
shell脚本2
条件测试分类 测试特定的表达式是否成立,当条件成立时,测试语句的返回值为0,否则为其他数值 测试命令格式:[ 条件表达式 ] 文件测试 格式:[ 操作符 文件或目录 ] -d:测试是否为目录(Di…...
2025年3月电子学会青少年机器人技术(五级)等级考试试卷-理论综合
青少年机器人技术等级考试理论综合试卷(五级) 分数:100 题数:30 一、单选题(共20题,共80分) 1. 2025年初,中国科技初创公司深度求索在大模型领域迅速崛起,其开源的大模型成为全球AI领域的焦…...
E3650工具链生态再增强,IAR全面支持芯驰科技新一代旗舰智控MCU
近日,全球嵌入式软件开发解决方案领导者IAR与全场景智能车芯引领者芯驰科技正式宣布,IAR Embedded Workbench for Arm已全面支持芯驰E3650,为这一旗舰智控MCU提供开发和调试一站式服务,进一步丰富芯驰E3系列智控芯片工具链生态&am…...
Linux之安装配置Nginx
Linux系统下安装配置Nginx的详细步骤如下: 一、准备工作 系统环境:确保Linux系统已安装,并且具有网络连接(以便在线安装依赖或下载Nginx)。 安装依赖:Nginx依赖于一些开发库和工具,如gcc、pcr…...
PC接入deepseek
<template> <div class"btn"> <el-button type"primary" plain click"openAIDrawer">AI问答</el-button> </div> <!-- deepSeek --> <el-drawer v-model"deepSeekData.drawerShow" :title&quo…...
Atlas 800I A2 离线部署 DeepSeek-R1-Distill-Llama-70B
一、环境信息 1.1、硬件信息 Atlas 800I A2 1.2、环境信息 注意:这里驱动固件最好用商业版,我这里用的社区版有点小问题 操作系统:openEuler 22.03 LTS NPU驱动:Ascend-hdk-910b-npu-driver_24.1.rc3_linux-aarch64.run NPU固…...
CF每日4题
1500左右的做到还是有点吃力 2093E 1500 二分答案 题意:给定一个长度为 n 的数组,现在要把它切成 k 份,求每一份最小的MEX中的最大值。 就是找最大值,但是这个值是所有段最小的值采用二分答案,二分这个值࿰…...
vue3 实现将html内容导出为图片、pdf和word
话不多说直接开始 本文使用到的开源插件库地址 wang1xiang 1.1 下载依赖 npm install html2canvas jspdf html-docx-js-typescript file-saver --save 2.1 下载工具 npm install html2image-pdf-word --save 3.1 页面使用 <template><div><div click"…...
手机端本地服务与后端微服务的技术差异
以下是手机内部本地服务与后端微服务架构及通信协议的对比分析,结合两者的核心设计差异与技术实现特点展开: 一、架构设计对比 维度手机端本地服务后端微服务核心目标资源效率、离线优先、动态更新高并发处理、分布式事务、服务治理服务拆分粒度按功能…...
音视频之H.265/HEVC环路后处理
H.265/HEVC系列文章: 1、音视频之H.265/HEVC编码框架及编码视频格式 2、音视频之H.265码流分析及解析 3、音视频之H.265/HEVC预测编码 4、音视频之H.265/HEVC变换编码 5、音视频之H.265/HEVC量化 6、音视频之H.265/HEVC环路后处理 类似于以往的视频编码标准,H…...
RSUniVLM论文精读
一些收获: 1. 发现这篇文章的table1中,有CDChat ChangeChat Change-Agent等模型,也许用得上。等会看看有没有源代码。 摘要:RSVLMs在遥感图像理解任务中取得了很大的进展。尽管在多模态推理和多轮对话中表现良好,现有模…...
redis特性及应用场景
文章目录 什么是redis?热库redis作为热库的特性redis适用场景 什么是redis? redis在系统架构中的位置就是冷热分离架构的热数据库位置, redis就是热库, 我们一般说缓存数据库。 其他的像MySQL、SQL Server这种关系数据库、MongoDB…...
Java中正则表达式使用方法
1. 正则表达式概述 正则表达式(Regular Expression,简称 Regex)是一种用于匹配字符串的模式工具。在 Java 中,正则表达式通过 java.util.regex 包实现,主要涉及以下两个类: Pattern:表示一个编…...
CSS基础
1. CSS入门 1.1. CSS是什么 CSS是Cascading Style Sheets的缩写,翻译为层叠样式表。CSS是一种样式表语言,用来描述HTML文档的表现方式,如字体、色彩、背景色等等。我们先从一段简单的CSS代码开始。 代码1 CSS示例 p {color: red; }这段代…...
【Linux系统篇】:什么是信号以及信号是如何产生的---从基础到应用的全面解析
✨感谢您阅读本篇文章,文章内容是个人学习笔记的整理,如果哪里有误的话还请您指正噢✨ ✨ 个人主页:余辉zmh–CSDN博客 ✨ 文章所属专栏:Linux篇–CSDN博客 文章目录 一.信号概念1.生活角度的信号2.技术应用角度的信号3.补充内容前…...
SpringSecurity源码解读AbstractAuthenticationProcessingFilter
一、介绍 AbstractAuthenticationProcessingFilter 是 Spring Security 框架里的一个抽象过滤器,它在处理基于表单的认证等认证流程时起着关键作用。它继承自 GenericFilterBean,并实现了 javax.servlet.Filter 接口。此过滤器的主要功能是拦截客户端发送的认证请求,对请求…...
Python torchvision.transforms 下常用图像处理方法
torchvision.transforms 是 PyTorch 用于处理图像数据的一个模块,提供了丰富的图像变换功能。 1. transforms.Compose 的使用方法 transforms.Compose 用于将多个 transforms 操作组合起来,形成一个变换序列,然后按顺序对图像进行处理。其输…...
Zynq7020 制作boot.bin及烧录到开发板全流程解析
Zynq7020作为Xilinx推出的经典SoC芯片,其PS(Processing System)与PL(Programmable Logic)协同工作的特性使其在嵌入式开发中广泛应用。然而,初次接触Zynq的开发者在制作启动文件boot.bin及烧录时࿰…...
【办公类-89-02】20250424会议记录模版WORD自动添加空格补全下划线
背景需求 4月23日听了一个MJB的征文培训,需要写会议记录 把资料黏贴到模版后,发现每行需要有画满下划线 原来做这套资料,就是手动按空格到一行末,有空格才会出现下划线,也就是要按很多的空格(凑满一行&…...
Python-36:饭馆菜品选择问题
问题描述 小C来到了一家饭馆,这里共有 nn 道菜,第 ii 道菜的价格为 a_i。其中一些菜中含有蘑菇,s_i 代表第 ii 道菜是否含有蘑菇。如果 s_i 1,那么第 ii 道菜含有蘑菇,否则没有。 小C希望点 kk 道菜,且希…...
某大型电解铝厂电解系统谐波治理装置改造沃伦森电气
电解铝行业谐波治理解决方案——无源滤波装置优化升级,保障稳定运行 在电解铝生产过程中,谐波污染问题严重影响电网电能质量,甚至可能导致滤波装置损坏,引发群爆事故。河南登封某大型电解铝厂通过无源滤波装置智能化改造ÿ…...
基于YOLO+DeepSeek的农作物病虫害检测系统
前言 本系统是一个基于YOLODeepSeek的农作物病虫害检测系统。 可使用YOLOV1-YOLOV12的任意模型进行目标检测。可以实现检测图片、批量检测图片、视频检测、摄像头检测四种方式。 能够检测出[“苹果-黑腐病”, “苹果-健康”, “苹果-结痂”, “甜椒-细菌性斑疹”, “甜椒-健康…...
Python实现技能记录系统
Python实现技能记录系统 来自网络,有改进。 技能记录系统界面如下: 具有保存图片和显示功能——允许用户选择图片保存,选择历史记录时若有图片可预览图片。 这个程序的数据保存在数据库skills2.db中,此数据库由用Python 自带的…...
【专题刷题】二分查找(一):深度解刨二分思想和二分模板
📝前言说明: 本专栏主要记录本人的基础算法学习以及LeetCode刷题记录,按专题划分每题主要记录:(1)本人解法 本人屎山代码;(2)优质解法 优质代码;ÿ…...
基于Python+Flask的MCP SDK响应式文档展示系统设计与实现
以下是使用Python Flask HTML实现的MCP文档展示系统: # app.py from flask import Flask, render_templateapp Flask(__name__)app.route(/) def index():return render_template(index.html)app.route(/installation) def installation():return render_templa…...
Flask + ajax上传文件(一)
一、概述 本教程将教你如何使用Flask后端和AJAX前端实现文件上传功能,包含完整的代码实现和详细解释。 二、环境准备 1. 所需工具和库 Python 3.xFlask框架jQuery库Bootstrap(可选,用于美化界面)2. 安装Flask pip install flask三、项目结构 upload_project/ ├── a…...
【每天一个知识点】熵(Entropy)
“熵(Entropy)”是信息论、热力学、机器学习等多个领域的核心概念。它可以用一句话概括为: 🔑 熵表示系统的不确定性或信息混乱程度。 📚 一、信息论中的熵(Information Entropy) 在 Claude Sh…...
GIT 使用小记
全局设置 PS C:\workspace> git config --global user.name "FreeMan" PS C:\workspace> git config --global user.email "12323772wawhyuser.noreply.gitee.com" PS C:\workspace> git remote add origin https://gitee.com/wawhy/mountain.git…...
如何保证高防服务器中的系统安全?
对于高防服务器中的系统安全,企业通常会采取一系列的防护措施和策略防止网络攻击、入侵、恶意软件和其他网络安全威胁,下面是几个较为主要的安全防护措施,能够帮助企业提升高防服务器的安全性。 定期更新服务器中操作系统以及所有安装的软件&…...
【go语言】window环境从源码编译go
背景 早就听过go语言已经实现自举, 也就是使用旧版本go,来编译新版源码,得到新版本go。 步骤 1. 下载源码 git clone https://github.com/golang/go.git 2. 开始make cd go\src make.bat 3. 等待编译 卡住就按下回车 验证新版本 ……...
医学图像(DICOM数据)读取及显示(横断面、冠状面、矢状面、3D显示)为什么用ITK+VTK,单独用ITK或者VTK能实一样功能吗?
在医学图像处理中,结合使用 ITK 和 VTK 是常见的做法,因为它们各自专注于不同的核心功能。以下是逐步解释为何代码中同时使用两者,以及单独使用是否可行的分析: 1. 为什么用ITK处理DICOM数据? 1.1 ITK的DICOM处理优势…...
TiDB 深度解析与 K8S 实战指南
一、TiDB 核心特性与架构原理 1. 核心特性 分布式架构: 采用计算(TiDB Server)、存储(TiKV)、调度(PD)分离设计,支持水平扩展至 PB 级数据量。通过 PD 动态调度 Region(…...
WPS右键菜单中“上传到云文档”消失,使用命令行注册解决
关于上传到wps云文档,右键菜单莫名消失的问题 尝试在WPS设置显示上传到wps云文档的右键菜单,以及使用设置和修复工具修复,均无法显示菜单。 最终解决方法: regsvr32 "D:\Program Files (x86)\WPS Office\12.1.0.20784\offic…...
计算机求职面经内容与技巧分享
计算机求职面经内容与技巧分享 一、求职前的充分准备 (一)简历优化 突出技术能力:在简历中,务必清晰呈现自己精通的编程语言,例如熟练掌握 Java、Python 等语言的核心语法、常用库及框架。详细列举熟悉的技术栈&#x…...
java Springboot使用扣子Coze实现实时音频对话智能客服
一、背景 因公司业务需求,需要使用智能客服实时接听顾客电话。 现在已经完成的操作是,智能体已接入系统进行对练,所以本文章不写对联相关的功能。只有coze对接~ 扣子提供了试用Realtime WebSocket,点击右上角setting配…...
焦化烧结行业无功补偿解决方案—精准分组补偿 稳定电能质量沃伦森
在焦化、烧结等冶金行业,负荷运行呈现长时阶梯状变化,功率波动相对平缓,但对无功补偿的分组精度要求较高。传统固定电容器组补偿方式无法动态跟随负荷变化,导致功率因数不稳定,甚至可能因谐波放大影响电网安全。 行业…...
机器人项目管理新风口:如何高效推动智能机器人研发?
在2025年政府工作报告中,“智能机器人”首次被正式纳入国家发展战略关键词。从蛇年春晚的秧歌舞机器人惊艳亮相,到全球首个人形机器人马拉松的热议,智能机器人不仅成为科技前沿的焦点,也为产业升级注入了新动能。而在热潮背后&…...
ZooKeeper配置优化秘籍:核心参数说明与性能优化
#作者:张桐瑞 文章目录 tickTime:Client-Server通信心跳时间initLimit:Leader-Follower初始通信时限syncLimit:Leader-Follower同步通信时限dataDir:数据文件目录clientPort:客户端连接端口服务器名称与地…...
uniapp -- 实现微信小程序、app、H5端视频上传
布局及实现代码: <template><view class"flex flex-column p-4 grid-gap-4"><view class"flex flex-column grid-gap-4 bg-white p-4 rounded-4"><view class"font-weight-600">视频名称</view><i…...
2025年Redis分片存储性能优化指南
一、分片规则与负载均衡 动态哈希分片 采用CRC16算法计算键哈希值,通过hash_slot CRC16(key) % 16384确定槽位分布,结合Redis Cluster自动管理槽位迁移。 总分片数按需动态调整,例如从16节点扩容至32节点时,触发槽位重分配以…...