SSR同构渲染深度解析
同构渲染(Isomorphic Rendering)是SSR(服务器端渲染)的核心概念,指同一套代码既能在服务器端运行,也能在客户端运行。下面我将从原理到实践全面介绍SSR同构渲染。
一、同构渲染核心原理
1. 基本工作流程
1. 用户请求
2. 服务器执行React/Vue渲染
3. 返回完整HTML
4. 浏览器加载JS
5. JS“接管”页面(Hydration)
6. 后续交互由前端框架处理
2. 关键机制对比
机制 | 服务器端 | 客户端 |
---|---|---|
渲染目标 | 生成完整HTML | DOM更新 |
数据获取 | 直接调用API | 通过fetch/XHR获取 |
生命周期 | 只执行到componentDidMount前 | 完整生命周期 |
路由处理 | 静态路由匹配 | 动态路由导航 |
二、同构渲染实现方案
1. React同构示例
// shared/App.js - 同构组件
import React from 'react';const App = ({ serverData }) => (<div><h1>同构应用</h1><p>服务器数据:{serverData}</p></div>
);
export default App;// server/render.js - 服务器渲染
import { renderToString } from 'react-dom/server';
import App from '../shared/App';const html = renderToString(<App serverData="从API获取的数据" />);// client/hydrate.js - 客户端注水
import { hydrate } from 'react-dom';
import App from '../shared/App';hydrate(<App serverData={window.__INITIAL_DATA__} />, document.getElementById('root'));
2. Vue同构示例
// shared/App.vue
<template><div><h1>同构应用</h1><p>服务器数据:{{ serverData }} </p></div>
</template><script>
export default {props: ['serverData']
}
</script>// server/entry-server.js
import { renderToString } from '@vue/serrver-renderer';
import { createApp } from './app';export async function render(url) {const { app } = createApp();const html = await renderToString(app);return html;
}// client/entry-client.js
import { createApp } from './app';const { app } = createApp();
app.mount('#app');
三、同构数据管理
1. 数据预取方案
// 定义静态数据需求方法
class PostPage extends React.Component {static async getInitialProps({ req }) {const res = await fetch(`https://api.example.com/posts/${req.params.id}`);return { post: await res.json() };}render() {return <article>{this.props.post.content}</article>;}
}// 服务器端处理
async function handleRender(req, res) {const props = await PostPage.getInitialProps({ req });const html = renderToString(<PostPage {...props} />);// 将数据注入到HTML中res.send(`<html><body><div id="root">${html}</div><script>window.__INITIAL_PROPS__ = ${JSON.stringify(props)};</script></body></html>`);
}
2. 状态同构方案(Redux)
// shared/store.js
import { createStore, applyMiddleware } from 'redux';
import thunk from 'redux-thunk';
import rootReducer from './reducers';export function createServerStore(initialState){return createStore(rootReducer,initialState,applyMiddleware(thunk));
}// server/render.js
import { Provider } from 'react-redux';
import { createServerStore } from '../shared/store';async function renderApp(req) {const store = createServerStore();await store.dispatch(fetchData(req.url)); // 预取数据const html = renderToString(<Provider store={store}><App /></Provider>);return {html,state: store.getState()}
}// client/hydrate.js
import { createClientStore } from '../shared/store';const store = createClientStore(window.__INITIAL_STATE__);
hydrate(<Provider store={store}><App /></Provider>,document.getElementById('root')
);
四、同构路由处理
1. React Router同构实现
// shared/routes.js
import { StaticRouter, BrowserRouter } from 'react-router-dom';// 服务器端使用StaticRouter
export function ServerRouter({ url, children }) {return <StaticRouter location={url}>{children}</StaticRouter>
}// 客户端使用BrowserRouter
export function ClientRouter({ children }) {return <BrowserRouter>{children}</BrowserRouter>
}// server/render.js
import { ServerRouter } from '../shared/routes';
function renderApp(req) {const html = renderToString(<ServerRouter url={req.url}><App /></ServerRouter>);return html;
}// client/hydrate.js
import { ClientRouter } from '../shared/routes';hydrate(<ClientRouter><App /></ClientRouter>,document.getElementById('root')
);
2. Vue Router同构实现
// shared/router.js
import { createRouter, createWebHistory, createMemoryHistory } from 'vue-router';export function createVueRouter(isServer) {const history = isServer ? createMemoryHistory(): createWebHistory();return createRouter({history,routes: [/* 路由配置 */]});
}// server/entry-server.js
import { createVueRouter } from '../shared/router';export async function render(url) {const router = createVueRouter(true);await router.push(url);await router.isReady();const app = createApp({ router });const html = await renderToString(app);return { html };
}// client/entry-client.js
import { createVueRouter } from '../shared/router';const router = createVueRouter(false);
const app = createApp({ router });
app.mount('#app');
五、同构渲染优化策略
1. 组件级缓存
// React组件缓存装饰器
function cachable(Component) {const cache = new Map()return class CachedComponent extends React.Component {static async getInitialProps(ctx) {const cacheKey = JSON.stringify(ctx.req.url);if (cache.has(cacheKey)) {return cache.get(cacheKey);}const props = await Component.getInitialProps(ctx);cache.set(cacheKey, props);return props;}render() {return <Component {...this.props} />}};
}@cachable
class ExpensiveComponent extends React.Component {// ...
}
2. 流式渲染
// React流式渲染示例
import { renderToNodeStream } from 'react-dom/server';app.get('/', (req, res) => {res.write('<!DOCTYPE html><html><head><title>流式渲染</title></head><body><div id="root">');const stream = renderToNodeStream(<App location={rerq.url} />);stream.pipe(res, {end: false });stream.on('end', () => {res.write('</div><script src="/client.js"></script></body></html>');res.end();})
})
3. 渐进式注水
// 使用React.lazy和Suspense实现渐进式注水
const HeavyComponent = React.lazy(() => import('./HeavyComponent'));function App() {return (<div><h1>关键内容</h1><Suspense fallback={<div>加载中...</div>}><HeavyComponent /></Suspense></div>);
}// 客户端注水时优先处理关键内容
hydrateRoot(document.getElementById('root'), <App />, {onRecoverableError(error) {console.log('可恢复错误:', error);}
})
六、同构渲染常见问题解决方案
1. 全局变量问题
// 安全使用window/document的方案
const canUseDOM = typeof window !== 'undefined' && typeof window.document !== 'undefined';function getDocument() {return canUseDOM ? document : null;
}// 使用
const doc = getDocument();
if (doc) {// 客户端特有操作doc.title = '同构应用';
}
2. 样式处理方案
// CSS Modules同构处理
import styles from './App.module.css';function App() {return (<div className={styles.container}>{/* 内容 */}</div>);
}// 服务器端收集样式
import { ServerStyleSheet } from 'styled-components';const sheet = new ServerStyleSheet();
const html = renderToString(sheet.collectStyled(<App />));
const styleTags = sheet.getStyleTags();// 注入到HTML
res.send(`<html><head>${styleTags}</head><body><div id="root">${html}</div></body></html>
`);
3. 第三方库兼容性
// 动态导入浏览器特有库
function loadBrowserLibrary() {if (typeof window === 'undefined') {return Promise.resolve(null); // 服务器端返回空}return import('browser-only-library').then(mod => mod.default);
}// 使用
loadBrowserLibrary().then(lib => {if (lib) {// 客户端特有逻辑lib.init();}
})
七、同构渲染测试策略
1. 渲染一致性测试
// 使用Jest测试同构渲染
describe('同构渲染测试', () => {let serverHTML, clientHTML;beforeAll(async () => {// 模拟服务器渲染serverHTML = renderToString(<App />); // 模拟客户端渲染const container = document.createElement('div');document.body.appendChild(container);render(<App />, container);clientHTML = container.innerHTML;});it('服务器和客户端渲染结果应该匹配', () => {// 简化比较,忽略data-reactid等属性const cleanServer = serverHTML.replace(/ data-[^=]+="[^"]*"/g, '');const cleanClient = clientHTML.replace(/ data-[^=]+="[^"]*"/g, '');expect(cleanServer).toEqual(cleanClient);});
})
2. 性能基准测试
// 使用 benchmark.js 测试渲染性能
const Benchmark = require('benchmark');
const suite = new Benchmark.Suite;suite.add('服务器端渲染', {defer: true,fn: deferred => {renderToString(<App />, () => deferred.resolve());}}).add('客户端渲染', {fn: () => {const container = document.createElement('div');render(<App />, container);}}).on('cycle', event => {console.log(String(event.target));}).run();
八、同构渲染进阶模式
1. 微前端同构
// 使用Module Federation实现同构微前端
// shell-app/webpack.config.js
module.exports = {plugins: [new ModuleFederationPlugin({remotes: {remoteApp: isServer ? 'remoteApp@http://localhost:3001/server/remoteEntry.js': 'remoteApp@http://localhost:3001/client/remoteEntry.js'}})]
};// 动态加载远程组件
const RemoteComponent = React.lazy(() => import('remoteApp/Component'));function App() {return (<Suspense fallback="加载中..."><RemoteComponent /></Suspense>)
}
2. 边缘同构渲染
// Cloudflare Workers 同构渲染示例
addEventListener('fetch', event => {event.respondWith(handleRequest(event.request));
});async function handleRequest(request) {const url = new URL(request.url);const html = url.pathname.startsWith('/_next') ? await fetchFromOrigin(request) // 静态资源直接回源: await renderApp(request); // 页面请求执行SSRreturn new Response(html, {headers: { 'Content-Type': 'text/html' },});
}async function renderApp(request) {// 执行 React SSRconst stream = await renderToReadableStream(<App url={request.url} />);return new Response(stream, {headers: { 'Content-Type': 'text/html' },});
}
相关文章:
SSR同构渲染深度解析
同构渲染(Isomorphic Rendering)是SSR(服务器端渲染)的核心概念,指同一套代码既能在服务器端运行,也能在客户端运行。下面我将从原理到实践全面介绍SSR同构渲染。 一、同构渲染核心原理 1. 基本工作流程 …...
【论文阅读/复现】RT-DETR的网络结构/训练/推理/验证/导出模型
利用ultralytics仓库,复现RT-DETR官方实验环境。 使用基于ResNet50和ResNet101的RT-DETR。 目录 一 RT-DETR的网络结构 1 编码器结构 2 RT-DETR 3 CCFF中的融合块 4 实验结果 二 RT-DETR的安装/训练/推理/验证/导出模型 1 安装 2 配置文件 3 训练 4 推理 …...
KUKA机器人关机时冷启动介绍
KUKA机器人在正常关机时,可以从示教器上操作。在示教器上操作时需要选择“冷启动”方式关闭计算机。等示教器屏幕关闭之后,再把主开关旋钮关闭。 一、先登录【管理员】权限,再在【主菜单】下选择【关机】。 二、在关机的默认中,…...
MCP Java SDK 介绍与使用指南
MCP与MCP Java SDK 概念 MCP 是什么? 模型上下文协议(Model Context Protocol, MCP)是用于标准化AI模型与工具间通信的规范。通过定义通用接口,确保不同AI组件(如模型推理服务、工具插件)能无缝协作。MCP …...
【Java核心】一文理解Java面向对象(超级详细!)
一:概述 1.1Java类及类的成员 属性、方法、构造器、代码块、内部类 1.2 面向对象的特征 封装、继承、多态(抽象) 1.3 其它关键字的使用 This、super、package、import、static、final、interface、abstract 1.4 面向对象和面向过程 &…...
2025年DDoS攻击防御全解析:应对超大流量的实战策略
一、2025年DDoS攻击的新趋势 超大规模攻击常态化:攻击流量突破300Gbps,部分案例甚至达到T级规模,传统单点防御已无法应对。 混合攻击模式盛行:攻击者结合应用层(HTTP Flood、CC攻击)与网络层(U…...
【动态导通电阻】 GaN PiN二极管电导调制对动态 RON 的影响
2020 年,浙江大学电气工程学院的Shaowen Han等人采用实验研究的方法,对垂直 GaN-on-GaN PiN 二极管中电导调制的瞬态行为及其对动态导通电阻(RON)的影响进行了深入探究。他们基于高质量的 GaN 基板开发的垂直 GaN-on-GaN 功率器件具有高电流容量和高击穿电压等优势,而与间…...
第十六届蓝桥杯 2025 C/C++B组第一轮省赛 全部题解(未完结)
目录 前言: 试题A:移动距离 试题C:可分解的正整数 试题D:产值调整 试题E:画展布置 前言: 我参加的是第一轮省赛,说实话第一次参加还是比较紧张的,真到考场上看啥都想打暴力&…...
MySQL 实战 45 讲 笔记 ----来源《极客时间》
01 | 基础架构:一条SQL查询语句是如何执行的? 1. MySQL 可以分为 Server层 和 存储引擎层 两部分。Server 层包括连接器、查询缓存、分析器、优化器、执行器等。存储引擎层支持 InnoDB、MyISAM等. (1) 连接器:管理连接,权限认证…...
海思SD3403边缘计算AI核心设备概述
1、海思SD3403边缘计算AI设备4TOPS算力(SD3403模组) 2、AI训练服务器 (≥60TOPS算力 INT8 算力越高AI训练速度越快) 3、普通监控IPC摄像机(低成本,批量化安装项目) 4、AI数据标定工作终端 (≥10TOPS算力 IN…...
算法设计:回溯法的基础原理与应用
目录 一、基本概念 二、适用问题 三、基本步骤 四、算法模式 递归回溯算法模式(求一个解) 非递归回溯算法模式(求一个解) 非递归回溯算法模式(求所有解) 五、经典应用 1数字组合问题 2数字排列问题…...
PyTorch 深度学习实战(23):多任务强化学习(Multi-Task RL)之扩展
之前的PyTorch 深度学习实战(23):多任务强化学习(Multi-Task RL)总结扩展运用代码如下: import torch import torch.nn as nn import torch.optim as optim import numpy as np from torch.distributions import Norm…...
音视频开发---视频编码基础
一、视频编码的必要性 1. 存储与传输成本高 未经编码压缩的原始视频的数据量极大,例如:一般电影的亮度信号采样频率为13.5MHz;色度信号的频带通常为亮度信号的一半或更少,为6.75MHz或3.375MHz。以4:2:2的采样频率为例,Y信号采用13.5MHz,色度信号U和V采用6.75MHz采样,…...
深入蜂窝物联网 第四章 Cat-1 与 5G RedCap:带宽、低时延与未来趋势
1. 前言与应用场景 随着物联网对带宽与时延的需求不断增长,LTE Cat-1 和 5G RedCap(Reduced Capability)应运而生: Cat-1:在传统 LTE 网络上提供最高 10 Mbps 下行、5 Mbps 上行,兼容性佳; 5G RedCap:在 5G NSA/SA 网络中提供 1–20 Mbps,时延可降至 10 ms 级,且模组…...
FPGA 39 ,FPGA 网络通信协议栈进阶,RGMII、ARP 与 UDP 协议与模块设计( RGMII、ARP、UDP原理与模块设计 )
目录 目录 一、核心原理 1.1 RGMII 接口:高效数据传输的物理桥梁 1.2 ARP 协议:IP 与 MAC 地址的动态映射引擎 1.3 UDP 协议:轻量级数据传输的高效选择 1.4 FPGA 实现流程 二、时序约束 2.1 时序约束理论…...
《系统分析师-第三阶段—总结(七)》
背景 采用三遍读书法进行阅读,此阶段是第三遍。 过程 本篇总结第13章第14章的内容 第13章 第14章 总结 系统设计分为概要设计与详细设计,然后重点讲解了处理流程设计,输入输出原型设计,面向对象设计、人机交互设计࿱…...
Lightroom 2025手机版:专业编辑,轻松上手
在摄影和图像编辑的世界里,Adobe Lightroom一直是一个不可或缺的工具。无论是专业摄影师还是摄影爱好者,都依赖它来提升照片的质量和视觉效果。今天,我们要介绍的 Lightroom 2025手机版,是Adobe公司为移动设备量身定制的照片编辑器…...
Cursor:AI时代的智能编辑器
在开发者社区掀起热潮的Cursor,正以破竹之势重塑编程工具格局。这款基于VS Code的AI优先编辑器,不仅延续了经典IDE的稳定基因,更通过深度集成的智能能力,将开发效率推向全新维度。2023年Anysphere公司获得的6000万美元A轮融资&…...
x86架构-k8s设置openebs的hostpath作为默认存储类的部署记录
文章目录 前言一、openebs是什么?二、准备步骤1.下载yaml文件2.准备一个新的单点k8s用于测试2.将openebs-operator.yaml中的镜像修改成使用国内加速源的 三、执行yaml1.openebs-operator.yaml2.local-hostpath-pvc.yaml和local-hostpath-pod.yaml 四、关于默认存储路…...
废品回收小程序:全链路数字化解决方案,赋能绿色未来
用户端:一键触达,便捷回收新体验 废品百科与估价指南:分类标准与实时价格一目了然,用户轻松掌握废品价值。一键预约,轻松回收:指尖轻点即可完成预约,上门服务省时省力。精准定位,导…...
Kotlin和JavaScript的对比
Kotlin和JavaScript有一些相似之处,但也存在显著的差异,下面从多个方面为你详细分析: 相似点 1. 语法灵活性 变量声明:二者在变量声明上都较为灵活。在JavaScript里,借助var、let和const可以声明变量。其中…...
蓝桥杯 5. 拼数
拼数 原题目链接 题目描述 给定 n 个正整数 a1, a2, …, an,你可以将它们任意排序。 现要将这 n 个数字连接成一排,即令相邻数字收尾相接,组成一个数。 问,这个数最大可以是多少。 输入格式 第一行输入一个正整数 n&#x…...
(即插即用模块-特征处理部分) 四十四、(2024 TGRS) FEM 特征增强模块
文章目录 1、Feature Enhancement Module2、代码实现 paper:FFCA-YOLO for Small Object Detection in Remote Sensing Images Code:https://github.com/yemu1138178251/FFCA-YOLO 1、Feature Enhancement Module 遥感图像中,小目标的特征通…...
“情况说明“以后,Unity XR 开发者如何选择?
Unity自4月7日发布了一系列“情况说明”,点进来的朋友应该都是看过的,此处不再赘述。此后引发了开发者社区的广泛关注和讨论。作为细分领域的XR开发者,此时也会面临着工具和版本的抉择或迷茫。笔者同样面临这些问题,因为要确定未来…...
c#版yolo可视化标注和一键免环境训练系统0429更新介绍
yolo免环境一键训练工具c#版yolo标注工具 ## 更新日志 - 2025.4.1: 1、软件上线 - 2025.4.6 1、调整界面,修复用户在1920*1080不能全部显示问题 2、修复 刷新当前目录 无法加载新增图片问题 3、新增 下一张图片快捷键 Enter或者ctrl↓&…...
Leetcode 3533. Concatenated Divisibility
Leetcode 3533. Concatenated Divisibility 1. 解题思路2. 代码实现 题目链接:3533. Concatenated Divisibility 1. 解题思路 这一题的话事实上如果我们原始的数组有序排列一下,然后依次考察每个元素是否可以被选用,此时,我们得…...
CosyVoice、F5-TTS、GPT-SoVITS、Fish-Speech声音模型项目深度对比:选型指南
在数字人、虚拟助手、智能客服等应用快速发展的背景下,文本转语音(TTS)和语音克隆技术已成为AI领域的核心技术之一。本文将对目前主流的四个开源语音合成项目——CosyVoice、F5-TTS、GPT-SoVITS 和 Fish-Speech进行全方位对比分析,…...
什么是DNS缓存?怎么清理DNS缓存?
在网络世界中,当我们输入一个网址想要访问某个网站时,计算机并不能直接识别“www.example.com”这样的网址,而是需要将其转换为对应的IP地址才能进行通信。这个转换过程由域名系统(DomainNameSystem,简称DNS࿰…...
基于STM32、HAL库的ATECC508A安全验证及加密芯片驱动程序设计
一、简介: ATECC508A是Microchip公司生产的一款加密认证芯片,提供以下主要特性: 基于硬件的ECDSA (Elliptic Curve Digital Signature Algorithm) 加密 支持SHA-256哈希算法 内置真随机数生成器(TRNG) 16个密钥存储槽位,可配置多种用途 支持I2C接口,最高1MHz时钟频率 超低…...
初中九年级学生体测准考证照片采集软件使用说明
随着中考体育测试的临近,各校陆续开始组织学生进行准考证照片、中考报名照片的采集工作。为方便学校集中采集和学生自主完成照片拍摄,本文将详细介绍使用"校园证件照采集平台"进行手机拍照线上采集的操作方法,帮助学校轻松完成体测…...
提供一些其他常见的字符串处理算法的Java示例
以下为你提供几种常见字符串处理算法的 Java 示例: 1. 字符串反转 反转字符串即把字符串中的字符顺序颠倒。 public class RemoveSpaces {public static String removeSpaces(String str) {return str.replaceAll("\\s", "");}public static…...
软件设计师-软考知识复习(2)
PERT图详解 PERT(Program Evaluation and Review Technique,计划评审技术)是一种用于项目管理的图形化工具,主要用于分析任务的时间安排、识别关键路径和优化资源分配。它特别适用于复杂项目,其中任务之间存在依赖关系…...
Qwen3快速部署 Qwen3-0.6B、Qwen3-8B、Qwen3-14B,Think Deeper
文章目录 0 Qwen31 平台与环境安装1 模型下载2 模型测试 0 Qwen3 今天,通义千问Qwen团队正式开源推出 Qwen3,这是 Qwen 系列大型语言模型的最新成员。最新的Qwen3系列模型具备双模推理能力(深入思考/快速响应)、支持119种语言及方…...
【C到Java的深度跃迁:从指针到对象,从过程到生态】第四模块·Java特性专精 —— 第十七章 IO流:超越FILE*的维度战争
一、从C文件操作到Java流的进化 1.1 C文件操作的原始挑战 C语言通过FILE*和低级文件描述符进行I/O操作,存在诸多限制: 典型文件复制代码: #include <stdio.h> int copy_file(const char* src, const char* dst) { FILE* in fope…...
Leetcode刷题记录22——滑动窗口最大值
题源:https://leetcode.cn/problems/sliding-window-maximum/description/?envTypestudy-plan-v2&envIdtop-100-liked 题目描述: 思路一: 暴力遍历法,通过一个长度为k的滑动窗口遍历nums,将其中最大的数依次记…...
React 第三十四节 Router 开发中 useLocation Hook 的用法以及案例详解
一、useLocation基础用法 作用:获取当前路由的 location 对象 返回对象结构: {pathname: "/about", // 当前路径search: "?namejohn", // 查询参数(URL参数)hash: "#contact", …...
BT134-ASEMI机器人功率器件专用BT134
编辑:LL BT134-ASEMI机器人功率器件专用BT134 型号:BT134 品牌:ASEMI 封装:TO-126 批号:最新 引脚数量:3 封装尺寸:如图 特性:双向可控硅 工作结温:-40℃~150℃…...
十五种光电器件综合对比——《器件手册--光电器件》
十五、光电器件 名称 原理 特点 应用 发光二极管(LED) 基于半导体材料的电致发光效应,当电流通过时,电子与空穴复合,释放出光子。 高效、节能、寿命长、响应速度快、体积小。 广泛用于指示灯、照明、显示&#…...
网络安全攻防演练实训室建设方案
一、引言 在数字化浪潮席卷全球的当下,网络已深度融入社会的各个层面,成为推动经济发展、社会进步和科技创新的关键力量。从日常生活中的移动支付、社交互动,到企业运营中的数据管理、业务拓展,再到国家关键基础设施的运行&#…...
极客天成受邀参加2050大会,共赴人工智能科技盛宴
2025年4月25日,备受瞩目的2050大会在杭州云栖小镇盛大开幕。作为科技领域的佼佼者,北京极客天成科技有限公司受邀参加了此次盛会,与全球科技爱好者共同探索科技的未来。 大会盛况空前,科技盛宴开启 2050大会是由杭州市云栖科技创…...
GUI_DrawPixel 函数详解
GUI_DrawPixel 是嵌入式GUI库中的基础像素绘制函数,用于在指定坐标绘制单个像素点。下面我将详细介绍这个函数的功能、实现和使用方法。 1. 函数功能 在显示屏的指定位置(x,y)绘制一个像素点 使用当前设定的颜色进行绘制 是构建所有高级图形(线、圆、…...
AWS MSK 集群升级前配置检查:保障升级平稳进行的关键步骤
在 AWS Managed Streaming for Apache Kafka (MSK) 集群升级之前,进行全面的配置检查至关重要。本文将介绍一个用于 MSK 升级前配置检查的 Bash 脚本,帮助您识别潜在的风险点,确保升级过程的顺利进行。 为什么需要升级前检查? AWS MSK 提供了自动升级功能,但在升级过程中,不…...
leetcode 2516. 每种字符至少取 K 个
题目描述 滑动窗口问题 可以转化为求按照题目要求从两端取走字符后,中间部分的最大长度。中间部分就是一个滑动窗口。 class Solution { public:int takeCharacters(string s, int k) {vector<int> count(3,0);int n s.size();for(int i 0;i <n;i){cou…...
通信原理第七版与第六版区别附pdf
介绍 我用夸克网盘分享了「通信原理 第7版》樊昌信」,链接:https://pan.quark.cn/s/be7c5af4cdce 《通信原理(第7版)》是在第6版的基础上,为了适应当前通信技术发展和教学需求,并吸取了数十所院校教师的反…...
CPU 空转解析
在编程中,“避免 CPU 空转” 指的是防止程序在等待某个条件满足时,无意义地消耗 CPU 资源。以下是对这一问题的详细解释: 1. 什么是 CPU 空转? 当代码中出现类似以下逻辑时: while not condition_met: # 循环检查条…...
云蝠智能大模型智能呼叫:赋能零售行业服务,助力客户增长
在数字化浪潮席卷全球的今天,零售行业正面临前所未有的变革压力。消费者需求日益个性化、市场竞争愈发激烈,传统的人工客服模式已难以满足企业对高效触达、精准营销和极致体验的需求。而云蝠智能大模型智能呼叫系统,凭借其突破性的AI技术和深…...
Consul安装部署(Windows环境)
部署资料链接:https://download.csdn.net/download/ly1h1/90722829 1.下载 Consul 1.访问 Consul 官方下载页面:Install | Consul | HashiCorp Developer 2.选择适合 Windows 的版本(如 consul_1.16.1_windows_amd64.zipÿ…...
Sql刷题日志(day7)
面试: 1、怎么样的数据挖取能真正对业务起到指导作用? 明确的业务目标:开始之前明确你想通过数据挖掘解决的业务问题。这些问题应具体、可量化,并与业务战略紧密相关。正确的数据集:确保使用的数据与你的业务问题相关…...
【MuJoCo仿真】开源SO100机械臂导入到仿真环境
主要参考:https://github.com/jpata/gym-so100/tree/integration/gym_so100/assets/trs_so_arm100 参考:(八)lerobot开源项目扩展so100的仿真操控(操作记录)_so100机械臂 仿真-CSDN博客 下载:…...
redis 有序集合zrange和zrangebyscore的区别
起因是查询数据,用了zrangebyscore 但是一直显示没数据 具体命令zrangebyscore key 0 -1 withscores, 原有印象中一直是这么用的,但是突然查不出来了, 于是搜了下问题所在。 通过分数查看 不能用0和-1表示最小和最大,只能用分数来…...