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

Vue3编译器深度解析:从模板编译到极致性能优化

一、编译技术架构演进

1.1 Vue2到Vue3编译架构升级


1.2 编译阶段性能基准对比

优化项Vue2编译耗时Vue3编译耗时性能提升
模板解析速度12ms/千节点3ms/千节点75%
AST遍历速度8ms/层级2ms/层级68%
代码生成速度15ms/组件4ms/组件73%
内存占用峰值84MB32MB62%

二、模板编译核心过程

2.1 三阶段处理架构


2.2 静态提升实战案例

// 原始模板<template>  <div>    <header class="header">{{ title }}</header>    <main :class="mainClass">内容区</main>    <footer>Copyright 2023</footer>  </div></template>// 编译后代码(静态提升优化)const _hoisted_1 = createStaticVNode("<footer>Copyright 2023</footer>")function render() {  return (_openBlock(),    createBlock('div', null, [      createVNode('header', { class: "header" }, _toDisplayString(_ctx.title), 1),      createVNode('main', { class: _ctx.mainClass }, "内容区", 2),      _hoisted_1    ])  )}

三、高阶优化策略剖析

3.1 预字符串化优化

// 静态节点数组优化示例// 原始模板<template>  <div>    <section>      <p>静态段落1</p>      <p>静态段落2</p>      <p>静态段落3</p>    </section>  </div></template>// 优化后预字符串化处理const _hoisted_1 = createStaticVNode(  "<section><p>静态段落1</p><p>静态段落2</p><p>静态段落3</p></section>")function render() {  return (_openBlock(), createBlock('div', null, [_hoisted_1]))}

3.2 缓存事件处理器

// 配置编译器选项// vue.config.jsmodule.exports = {  chainWebpack: config => {    config.module      .rule('vue')      .use('vue-loader')      .tap(options => ({        ...options,        compilerOptions: {          cacheHandlers: true        }      }))  }}// 不同处理方式对比// 普通模式const _ctx = { handleClick: () => { /*...*/ } }createVNode('button', { onClick: _ctx.handleClick })// 缓存模式 const _cache = {}createVNode('button', {   onClick: _cache[1] || (_cache[1] = e => _ctx.handleClick(e)) })

四、动态模板优化引擎

4.1 动态标识符追踪

// 模板层级数据流向追踪<template>  <div>    <ChildComp :data="obj.prop" />    <span>{{ arr[offset] }}</span>  </div></template>// 编译结果(基于Proxy的数据绑定)function render() {  return (_openBlock(),    createBlock('div', null, [      createVNode(ChildComp, {         data: _ctx.obj.prop       }, null, 8 /* PROPS */, ["data"]),      createVNode("span", null, _toDisplayString(_ctx.arr[_ctx.offset]), 1)    ])  )}

4.2 分支优化策略模型

分支类型处理策略重渲染触发点更新复杂度
静态条件渲染完全提升O(0)
动态多条件分支Block树结构缓存父Block节点O(1)
列表条件过滤双向追踪列表项动/静态项O(n)
嵌套条件层级建立追踪链路各层级追踪标记O(log n)

五、编译器进阶用法

5.1 自定义编译指令

// 实现Lazy编译指令// lazy.tsconst LazyDirective: DirectiveTransform = (dir, node, context) => {  return {    props: [      createObjectProperty(        `onLazy`,        createFunctionExpression(          null,          dir.exp            ? `($event) => ${dir.exp}($event)`            : `() => {}`        )      )    ]  }}// 注册自定义指令// compilerOptions.tsapp.config.compilerOptions.directiveTransforms['lazy'] = LazyDirective// 模板应用<template>  <div v-lazy="handleScroll"></div></template>

5.2 编译器安全策略矩阵

安全机制编译器级别保护潜在风险点解决方案
XSS防御自动实体编码{{ rawHTML }}白名单过滤
表达式沙箱安全执行上下文Function构造环境变量约束
模板解析验证严格模式检查非法嵌套元素Schema校验
资源加载限制内联资源验证动态importCSP策略支持

六、编译性能深度调优

6.1 编译缓存方案实现

// 配置持久化缓存// vue.config.jsconst { createPersistentCache } = require('vue-compiler-cache')module.exports = {  chainWebpack: config => {    config.plugin('compile-cache')      .use(createPersistentCache({        cacheDirectory: '.vue-cache',        maxAge: 7 * 24 * 60 * 60 * 1000 // 7天      }))  }}// 组件级缓存命中统计Compiled: 1523 files  Cached: 1243 files (81.6% hit rate)Recompiled: 280 files

6.2 生产环境优化清单

- [ ] 开启模板静态提升(hoistStatic: true)  - [ ] 激活事件处理缓存(cacheHandlers: true)  - [ ] 配置资源内联阈值(inlineResourceLimit: 4096)  - [ ] 启用预字符串化(prefixStatic: true)  - [ ] 禁用开发调试功能(prodMode: true)  - [ ] 设定作用域ID生成策略(scopeId: 'stable')

💡 核心编译器配置项

// 完整编译器选项类型interface CompilerOptions {  mode?: 'module' | 'function'    // 代码生成模式  hoistStatic?: boolean           // 静态节点提升  cacheHandlers?: boolean         // 缓存事件处理器  scopeId?: string | null         // 作用域ID  inline?: boolean                // 内联模式编译  ssr?: boolean                   // 服务端渲染模式  prefixIdentifiers?: boolean     // 标识符前缀  bindingMetadata?: Record<string, 'data' | 'props' | 'setup'>}

🚀 性能极限挑战数据

测试场景Vanilla Vue3全优化模式优化量级
百万静态节点编译8.2s1.1s7.5x
混合模板增量编译460ms68ms6.8x
大型SPA首次编译12.4s3.1s4x
热更新速度(±10%)320ms85ms3.76x
CSS资源编译内存占用348MB92MB3.78x

🛠 专家级调试技巧

# 生成编译器中间产物vue-cli-service inspect --mode production > compile.log# AST可视化分析工具npm install vue-template-explorer -gvhtml-template-explorer input.vue > ast.html# 追踪编译管道流程export VUE_COMPILER_DEBUG=1npm run build 2>&1 | grep '[Compiler]'

本文深度揭示Vue3编译器的工作原理与极致优化手法,涵盖从模板解析到渲染代码生成的全链路技术细节,点击「收藏」获取编译器调试秘籍手册,关注作者追踪《Vue3编译黑魔法》直播课程。分享本文至技术社群可解锁SSR编译优化专题,访问文末「Playground」即刻体验代码编译实时交互!

相关文章:

Vue3编译器深度解析:从模板编译到极致性能优化

一、编译技术架构演进 1.1 Vue2到Vue3编译架构升级 1.2 编译阶段性能基准对比 优化项Vue2编译耗时Vue3编译耗时性能提升模板解析速度12ms/千节点3ms/千节点75%AST遍历速度8ms/层级2ms/层级68%代码生成速度15ms/组件4ms/组件73%内存占用峰值84MB32MB62% 二、模板编译核心过程 …...

Google Gemini 2.0 网页抓取真丝滑

网页抓取从未如此简单——这一切都要归功于谷歌突破性的多模态实时API Gemini 2.0 借助这个工具&#xff0c;你可以毫不费力地从任何网页提取数据&#xff0c;无论页面结构多么复杂、内容多么杂乱无章&#xff0c;或是需要提取非常特定的信息。 今天&#xff0c;我将通过自己实…...

Leetcode-100 二分查找常见操作总结

二分查找常见操作总结 1. 基本二分查找 目标: 在有序数组 nums 中查找 target 的索引&#xff08;如果存在&#xff09;。 适用场景: 需要在 有序数组 中查找某个特定元素。适用于无重复元素的情况。 示例: 输入 nums [1, 2, 3, 4, 5], target 3&#xff0c;输出 2。 d…...

Android: Handler 的用法详解

Android 中 Handler 的用法详解 Handler 是 Android 中用于线程间通信的重要机制&#xff0c;主要用于在不同线程之间发送和处理消息。以下是 Handler 的全面用法指南&#xff1a; 一、Handler 的基本原理 Handler 基于消息队列(MessageQueue)和循环器(Looper)工作&#xff…...

第149场双周赛:找到字符串中合法的相邻数字、重新安排会议得到最多空余时间 Ⅰ、

Q1、找到字符串中合法的相邻数字 1、题目描述 给你一个只包含数字的字符串 s 。如果 s 中两个 相邻 的数字满足以下条件&#xff0c;我们称它们是 合法的 &#xff1a; 前面的数字 不等于 第二个数字。两个数字在 s 中出现的次数 恰好 分别等于这个数字本身。 请你从左到右…...

深入解析Translog机制:Elasticsearch的数据守护者

一、为什么需要Translog&#xff1f; Elasticsearch的数据写入流程是先写入内存缓冲区&#xff0c;然后定期刷新到磁盘生成Lucene分段。由于内存数据易失性&#xff0c;若在刷新前发生宕机&#xff0c;未持久化的数据将永久丢失。Translog的诞生正是为了解决这一数据可靠性问题…...

音视频入门基础:MPEG2-TS专题(25)——通过FFmpeg命令使用UDP发送TS流

音视频入门基础&#xff1a;MPEG2-TS专题系列文章&#xff1a; 音视频入门基础&#xff1a;MPEG2-TS专题&#xff08;1&#xff09;——MPEG2-TS官方文档下载 音视频入门基础&#xff1a;MPEG2-TS专题&#xff08;2&#xff09;——使用FFmpeg命令生成ts文件 音视频入门基础…...

3、nFR52xx蓝牙学习(点亮第一个LED灯)

一、点灯代码&#xff1a; led.h文件 #ifndef __LED_H #define __LED_H#include "nrf52840.h"#define LED_0 NRF_GPIO_PIN_MAP(0,13) #define LED_1 NRF_GPIO_PIN_MAP(0,14) #define LED_2 NRF_GPIO_PIN_MAP(0,15) #define LED_3 …...

符号秩检验

内容来源 非参数统计&#xff08;第2版&#xff09; 清华大学出版社 王星 褚挺进 编著 符号秩检验 在符号检验的基础上&#xff0c;增加了数据绝对值大小的信息 检验统计量 用一个简单的例子来说明 样本数据 X i , i 1 , ⋯ , 6 X_i,i1,\cdots,6 Xi​,i1,⋯,6 如下 X …...

制造业数字化转型:流程改造先行还是系统固化数据?基于以MTO和MTS的投资回报分析

1. 执行摘要 制造业正经历一场深刻的数字化转型&#xff0c;企业面临着先进行流程改造以优化运营&#xff0c;还是直接上线系统以固化数据的战略选择。本文深入分析了以销定产&#xff08;MTO&#xff09;和以产定销&#xff08;MTS&#xff09;两种主要生产模式下&#xff0c…...

python相关笔记

一。 is和的区别 1.is看的是发票逻辑地址&#xff0c;用来判断两个变量是否引用同一个对象&#xff0c;is关注的是‘身份’ 2.判断两个对象是否具有相同的值&#xff0c;关注的是内容是否相等&#xff0c;也即值是否相等。 3. if x is None: print(x is None")...

C++(匿名函数+继承+多态)

#include <iostream> #include <cstring> #include <cstdlib> #include <unistd.h> #include <sstream> #include <vector> #include <memory>using namespace std;// 基类 Weapon class Weapon { protected:int atk; public:Weapon…...

界面架构 - MVVM (Qt)

MVVM MVVM 的主要特点示例示例功能示例代码ViewModel 类&#xff08;C&#xff09;主函数入口&#xff08;main.cpp&#xff09; QML 文件&#xff08;main.qml&#xff09;总结 MVVM&#xff08;Model-View-ViewModel&#xff09;架构是一种旨在进一步分离界面和业务逻辑的设计…...

在未归一化的线性回归模型中,特征的尺度差异可能导致模型对特征重要性的误判

通过数学公式来更清晰地说明归一化对模型的影响&#xff0c;以及它如何改变特征的重要性评估。 1. 未归一化的情况 假设我们有一个线性回归模型&#xff1a; y β 0 β 1 x 1 β 2 x 2 ϵ y \beta_0 \beta_1 x_1 \beta_2 x_2 \epsilon yβ0​β1​x1​β2​x2​ϵ 其…...

【大模型系列篇】大模型基建工程:使用 FastAPI 构建 MCP 服务器

今天我们将使用FastAPI来构建 MCP 服务器&#xff0c;Anthropic 推出的这个MCP 协议&#xff0c;目的是让 AI 代理和你的应用程序之间的对话变得更顺畅、更清晰。FastAPI 基于 Starlette 和 Uvicorn&#xff0c;采用异步编程模型&#xff0c;可轻松处理高并发请求&#xff0c;尤…...

基于微信小程序的智慧乡村旅游服务平台【附源码】

基于微信小程序的智慧乡村旅游服务平台&#xff08;源码L文说明文档&#xff09; 目录 4系统设计 4.1系统功能设计 4.2系统结构 4.3.数据库设计 4.3.1数据库实体 4.3.2数据库设计表 5系统详细实现 5.1 管理员模块的实现 5.1.1旅游景点管理…...

llm-universe 踩坑记录

踩坑 云服务器2G不够&#xff0c;因为后面用到内存向量数据库&#xff0c;把数据加载到内存&#xff0c;一个大点的pdf就导致整个服务器崩了。当时可以选择不加载大的文件&#xff0c;自己替换一个小点的pdf 注意点 LLM API.ipynb 这节要注意看下API的含义&#xff0c;了解m…...

【案例】跨境电商企业实践云成本优化,选对平台是关键

某跨境电商企业近年因业务发展迅猛&#xff0c;近年来在全球市场大力拓展业务。然而&#xff0c;伴随其全球化布局的深化&#xff0c;云资源成本逐年攀升&#xff0c;每年在云资源方面的投入超 500万元。庞大的云资源使用量虽支撑了业务的快速发展&#xff0c;但也带来了较高的…...

系统思考与时间管理

时间管理的真正秘诀&#xff1a;主动浪费时间&#xff1f; 巴菲特的私人飞机驾驶员觉得自己不够成功&#xff0c;于是向巴菲特请教应该怎么做。巴菲特让他列出了自己人生中最想实现的25个目标&#xff0c;并按重要程度排序&#xff0c;接着安排时间专注做前五件最重要的事情。…...

洛谷.P1563 [NOIP 2016 提高组] 玩具谜题

P1563 [NOIP 2016 提高组] 玩具谜题 - 洛谷 代码区&#xff1a; #include<algorithm> #include<iostream> #include<cstring> #include<string> #include<vector>using namespace std; const int MAX 1000005; struct PEOPLE {int cx;//0朝内…...

华为面试,机器学习深度学习知识点:

机器学习深度学习知识点&#xff1a; 机器学习一般有哪些分数&#xff0c;对于不同的任务&#xff1a; 分类任务&#xff1a; 准确率&#xff08;Accuracy&#xff09;&#xff1a;预测正确的样本数占总样本数的比例&#xff0c;公式为 Accuracy TPTNFPFN TPTN ​ &#xff0c…...

关于 数据库 UNION 和 UNION ALL 的使用,以及 分库分表环境下多表数据组合后的排序和分页问题的解决方案 的详细说明,并以表格总结关键内容

以下是关于 数据库 UNION 和 UNION ALL 的使用&#xff0c;以及 分库分表环境下多表数据组合后的排序和分页问题的解决方案 的详细说明&#xff0c;并以表格总结关键内容&#xff1a; 1. UNION 和 UNION ALL 的核心区别 1.1 定义与语法 UNION 功能&#xff1a;合并两个或多个 …...

架构设计基础系列:事件溯源模式浅析

图片来源网络&#xff0c;侵权删 ‌1. 引言‌ ‌1.1 研究背景‌ 传统CRUD模型的局限性&#xff1a;状态覆盖导致审计困难、无法追溯历史。分布式系统复杂性的提升&#xff1a;微服务架构下数据一致性、回滚与调试的需求激增。监管合规性要求&#xff1a;金融、医疗等领域对数…...

虚拟试衣间-云尚衣橱小程序-衣橱管理实现

衣橱管理实现 目标 (Goal): 用户 (User): 能通过 UniApp 小程序上传衣服图片。 后端 (Backend): 接收图片,存到云存储,并将图片信息(URL、用户ID等)存入数据库。 用户 (User): 能在小程序里看到自己上传的所有衣服图片列表。 技术栈细化 (Refined Tech Stack for this Pha…...

蓝桥杯省模赛 台阶方案

问题描述 小蓝要上一个楼梯&#xff0c;楼梯共有 n 级台阶&#xff08;即小蓝总共要走 n 级&#xff09;。小蓝每一步可以走 a 级、b 级或 c 级台阶。 请问小蓝总共有多少种方案能正好走到楼梯顶端&#xff1f; 输入格式 输入的第一行包含一个整数 n 。 第二行包含三个整数…...

Socket编程UDP

Socket编程UDP 1、V1版本——EchoServer2、网络命令2.1、ping2.2、netstat2.3、pidof 3、验证UDP——Windows作为client访问Linux4、V2版本——DictServer5、V3版本——简单聊天室 1、V1版本——EchoServer 首先给出EchoServer目录结构&#xff1a;服务器的类我们实现在UdpServ…...

无人机机体结构设计要点与难点!

一、无人机机体结构设计要点 1. 类型与应用场景匹配 固定翼无人机&#xff1a;需优化机翼升阻比&#xff0c;采用流线型机身降低气动阻力&#xff08;如大展弦比机翼设计&#xff09;。 多旋翼无人机&#xff1a;注重轻量化框架和对称布局&#xff08;如四轴/六轴碳纤维机…...

音视频(一)ZLMediaKit搭建部署

前言 一个基于C11的高性能运营级流媒体服务框架 全协议支持H264/H265/AAC/G711/OPUS/MP3&#xff0c;部分支持VP8/VP9/AV1/JPEG/MP3/H266/ADPCM/SVAC/G722/G723/G729 1&#xff1a;环境 ubuntu22.* ZLMediaKit downlaod:https://github.com/ZLMediaKit/ZLMediaKit or https://g…...

实战 | 餐厅点餐小程序技术解析:SpringBoot + UniApp 高效开发指南

&#x1f5a5;️ 一、系统架构概览 1.1 技术选型 为了确保开发效率和系统稳定性&#xff0c;我们采用以下技术栈&#xff1a; 模块技术选型后台服务SpringBoot MyBatis-Plus MySQL用户端&#xff08;点餐小程序&#xff09;UniApp&#xff08;Vue 语法&#xff09;师傅端&…...

合并相同 patient_id 的 JSON 数据为数组

问题 select patient_id,concat({"itemText":",item_text,","itemValue":",item_value,"}) from hs_patient_groups where active 1;eef41128c47c401abb7f8885a5f9fbdf {"itemText":"旧","itemValue"…...

AI安全:构建负责任且可靠的系统

AI已成为日常生活中无处不在的助力&#xff0c;随着AI系统能力和普及性的扩展&#xff0c;安全因素变得愈发重要。从基础模型构建者到采用AI解决方案的企业&#xff0c;整个AI生命周期中的所有相关方都必须共同承担责任。 为什么AI安全至关重要&#xff1f; 对于企业而言&…...

STM32单片机入门学习——第8节: [3-4] 按键控制LED光敏传感器控制蜂鸣器

写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难&#xff0c;但我还是想去做&#xff01; 本文写于&#xff1a;2025.04.02 STM32开发板学习——第8节: [3-4] 按键控制LED&光敏传感器控制蜂鸣器 前言开…...

Linux驱动入门——设备树详解

文章目录 一、设备树的引入与作用二、设备树的语法1. Devicetree格式1.1 DTS文件的格式1.2 node的格式1.3 properties的格式 2. dts文件包含dtsi文件3. 常用的属性3.1 #address-cells、#size-cells3.2 compatible3.3 model3.4 status3.5 reg 4. 常用的节点(node)4.1 根节点4.2 …...

Scala集合

Scala集合分为序列Seq、集Set、映射Map&#xff0c;都扩展自Iterable特质&#xff0c;且有可变和不可变版本。不可变集合操作后会返回新对象&#xff0c;可变集合则直接修改原对象。比如数组&#xff0c;不可变数组定义后大小不可变&#xff0c;修改会生成新数组&#xff1b;可…...

阿里云AI Studio 2.0:拖拽搭建企业级智能客服系统

一、平台能力全景 1.1 核心功能矩阵 模块子功能技术指标对话设计可视化流程编排支持50节点类型NLP引擎意图识别准确率行业TOP3&#xff08;92.6%&#xff09;知识管理多源数据接入15格式支持渠道对接全渠道覆盖8大平台SDK 1.2 企业级特性 关键优势&#xff1a; 日均对话承…...

java虚拟机---JVM

JVM JVM&#xff0c;也就是 Java 虚拟机&#xff0c;它最主要的作用就是对编译后的 Java 字节码文件逐行解释&#xff0c;翻译成机器码指令&#xff0c;并交给对应的操作系统去执行。 JVM 的其他特性有&#xff1a; JVM 可以自动管理内存&#xff0c;通过垃圾回收器回收不再…...

您的LarkXR专属顾问上线了!平行云官网新增 AI 小助手,手册同步升级!

遇到LarkXR技术问题&#xff1f;还在手动翻文档&#xff1f; Paraverse平行云官网双升级——AI小助手实时答疑 用户手册智能检索&#xff01; 助您快速定位解决方案&#xff0c;效率全面提升&#xff01; < 01 > AI 小助手—— 您的 LarkXR 智能顾问 欢迎我们的新成员…...

推导Bias² + Variance + σ²_ε

问题的背景 我们有一个真实函数 f ( x ) f(x) f(x) 和基于训练数据 D D D 训练得到的模型 f ^ ( x ; D ) \hat{f}(x;D) f^​(x;D)。对于任意输入 x x x&#xff1a; y y y 是真实的观测值&#xff0c;定义为 y f ( x ) ϵ y f(x) \epsilon yf(x)ϵ&#xff0c;其中 …...

javaSE知识梳理(一)

一.面向对象编程 1.面向对象的基本元素&#xff1a;类(class)和对象 ①类的声明 语法格式&#xff1a; [修饰符] class 类名{属性声明;方法声明; } ②对象的创建(new) 语法格式&#xff1a; //方式1&#xff1a;给创建有名对象 类名 对象名 new 类名();//方式2&#xff1…...

k8s statefulset pod重启顺序

在 Kubernetes 中&#xff0c;StatefulSet 的 Pod 重启顺序由以下规则和机制决定&#xff1a; 1. StatefulSet 的核心设计原则 StatefulSet 旨在管理有状态应用&#xff0c;其核心特性包括&#xff1a; 稳定的唯一标识&#xff1a;Pod 名称格式为 <statefulset-name>-&…...

记录学习的第十九天

现在这篇是记录一下4.1的学习。今天还没开始。 这篇是关于简单的动态规划的题目&#xff0c;思路比较清晰类似。 在这里先说一下有关动态规划的四个步骤&#xff1a; 1.确定子问题 2.确定dp数组的递推关系(dp数组也叫子问题数组) 3.确定求解的计算顺序 4.空间优化(初学者可…...

【实用技巧】电脑重装后的Office下载和设置

写在前面&#xff1a;本博客仅作记录学习之用&#xff0c;部分图片来自网络&#xff0c;如需引用请注明出处&#xff0c;同时如有侵犯您的权益&#xff0c;请联系删除&#xff01; 文章目录 前言下载设置总结互动致谢参考目录导航 前言 在数字化办公时代&#xff0c;Windows和…...

模拟集成电路设计与仿真 : Mismatch

前情提要 此為作者針對 mismatch ,進行資料統整,以便日後查詢原理 1. Mismatch (失配) random offset 靜態消除 : trimming動態消除 : auto zero ,choppingCMRRlinearity 理想差動對只有奇次諧波,沒有偶次諧波,但 mismatch 會引入殘存的偶次諧波PSRR2. Input Offset Volt…...

深度学习查漏补缺:4.数据分布的度量

一、数据分布差异的度量 1.KL散度&#xff08;Kullback-Leibler Divergence&#xff09; 什么是KL散度&#xff1f; KL散度是一种用来衡量两个概率分布之间差异的工具。你可以把它想象成一个“距离测量器”&#xff0c;但它不是传统意义上的距离&#xff08;比如两点之…...

银河麒麟V10 aarch64架构安装mysql教程

国产操作系统 ky10.aarch64 因为是arm架构&#xff0c;故选择mysql8&#xff0c;推荐安装8.0.28版本 尝试8.0.30和8.0.41版本均未成功&#xff0c;原因不明☹️ 1. 准备工作 ⏬ 下载地址&#xff1a;https://downloads.mysql.com/archives/community/ 2. 清理历史环境 不用管…...

【NLP 52、多模态相关知识】

生活应该是美好而温柔的&#xff0c;你也是 —— 25.4.1 一、模态 modalities 常见&#xff1a; 文本、图像、音频、视频、表格数据等 罕见&#xff1a; 3D模型、图数据、气味、神经信号等 二、多模态 1、Input and output are of different modalities (eg&#xff1a; tex…...

[NCTF2019]Fake XML cookbook [XXE注入]

题目源代码 function doLogin(){var username $("#username").val();var password $("#password").val();if(username "" || password ""){alert("Please enter the username and password!");return;}var data "…...

I²C总线高级特性与故障处理分析

IC总线高级特性与故障处理深度分析 目录 1. IC基础回顾 1.1 IC通信基本原理1.2 IC总线时序与协议1.3 寻址方式与读写操作 2. IC高级特性 2.1 多主机模式2.2 时钟同步与伸展2.3 高速模式与Fast-mode Plus2.4 10位寻址扩展 3. IC总线故障与锁死 3.1 断电锁死原理3.2 总线挂起与…...

【力扣hot100题】(039)二叉树的直径

这题在简单题中有点难度&#xff0c;主要是不要把边数和深度搞混&#xff08;我就这样&#xff09;。 我想了很久&#xff0c;发现如果当前节点没有右节点&#xff0c;就将它的右长度设为0&#xff0c;左节点同理&#xff0c;并且在递归是不会加一&#xff0c;而是将加一的操作…...

L2-001 紧急救援

注意题目没有说边的数量&#xff0c;实际最多有5e5条边&#xff0c;开小了第四个样例会错&#xff01;&#xff01;&#xff01; - 思路: Dijkstra 求最短路并且维护路径条数和最大人数。 #include<bits/stdc.h> using namespace std;typedef pair<int, int> pii…...