浅谈 JavaScript 性能优化
文章目录
- 概要
- 一、代码执行优化
- 1. 减少全局变量访问
- 2. 避免不必要的计算
- 3. 优化循环操作
- 二、内存管理优化
- 1. 减少内存泄漏
- 2. 对象池与内存复用
- 三、渲染性能优化
- 1. 避免强制同步布局
- 2. 减少 DOM 操作
- 3. 优化动画与合成
- 四、网络加载优化
- 1. 代码压缩与 Tree Shaking
- 2. 按需加载与懒加载
- 3. 缓存策略
- 五、其他优化技巧
- 1. 避免 eval() 和 with 语句
- 2. 使用高效的数据结构
- 3. 性能监控与分析
- 总结
- 性能优化之vue3
- 一、响应式系统优化
- 1. 避免过度响应式
- 2. 局部响应式替代全局响应式
- 二、组件设计优化
- 1. 使用 `v-once` 缓存静态内容
- 2. 使用 `v-memo` 缓存重复渲染的列表项
- 3. 组件懒加载与 Suspense
- 三、渲染与更新优化
- 1. 避免不必要的 watch
- 2. 优化计算属性
- 四、事件处理优化
- 1. 防抖/节流处理高频事件
- 2. 避免在循环中绑定复杂事件处理函数
- 五、内存管理优化
- 1. 手动清理副作用
- 2. 避免组件间循环引用
- 六、构建与部署优化
- 1. 代码分割与按需加载
- 2. 使用生产模式构建
- 性能优化检查清单
概要
JavaScript 性能优化是提升网页加载速度、交互流畅度和用户体验的关键手段。以下从代码执行效率、内存管理、渲染优化等方面进行浅谈。
一、代码执行优化
1. 减少全局变量访问
- 原因:全局变量在作用域链顶端,访问速度慢于局部变量。
- 优化:
- 将常用全局变量缓存为局部变量(如
const doc = document
)。 - 使用模块系统(ES6 Modules)或闭包封装变量,避免污染全局作用域。
- 将常用全局变量缓存为局部变量(如
2. 避免不必要的计算
- 防抖(Debounce)与节流(Throttle):
- 防抖:事件触发后延迟执行,若短时间内多次触发则重新计时(适用于搜索联想、窗口 resize 等)。
- 节流:限制事件触发频率,确保单位时间内最多执行一次(适用于滚动加载、高频点击等)。
- 示例代码:
// 防抖 function debounce(fn, delay) {let timer = null;return function (...args) {clearTimeout(timer);timer = setTimeout(() => fn.apply(this, args), delay);}; }// 节流(时间戳版) function throttle(fn, delay) {let lastTime = 0;return function (...args) {const now = Date.now();if (now - lastTime >= delay) {fn.apply(this, args);lastTime = now;}}; }
3. 优化循环操作
- 使用高效循环方式:
- 优先使用
for
循环而非forEach
(后者存在函数调用开销)。 - 缓存循环长度(如
for (let i = 0, len = arr.length; i < len; i++)
)。
- 优先使用
- 避免循环内的复杂操作:将耗时逻辑移至循环外。
二、内存管理优化
1. 减少内存泄漏
- 常见场景:
- 全局变量未及时清理(如意外挂载在
window
上的对象)。 - 定时器或事件监听器未移除(如
addEventListener
需搭配removeEventListener
)。 - DOM 元素与 JavaScript 对象的循环引用(如缓存 DOM 节点时未断开引用)。
- 全局变量未及时清理(如意外挂载在
- 优化方法:
- 使用严格模式(
'use strict'
)检测未声明变量。 - 手动清理定时器(
clearTimeout/clearInterval
)和事件监听器。 - 使用弱引用(
WeakMap
/WeakSet
)避免对象被意外引用。
- 使用严格模式(
2. 对象池与内存复用
- 对象池模式:预先创建一组可复用的对象,避免频繁创建/销毁带来的开销(如游戏中的子弹对象)。
- 示例:
const objectPool = {pool: [],create() {return this.pool.length ? this.pool.pop() : new Object();},recycle(obj) {// 重置对象状态obj.property = null;this.pool.push(obj);} };
三、渲染性能优化
1. 避免强制同步布局
- 原因:浏览器渲染流程为“样式计算 → 布局 → 绘制 → 合成”,强制同步布局(如在修改样式后立即读取布局属性)会触发额外重排。
- 优化:
- 批量修改样式:使用
classList
替代直接操作style
,或通过documentFragment
批量操作 DOM。 - 错误示例:
element.style.width = '100px'; // 触发布局 console.log(element.offsetWidth); // 强制同步布局,导致额外重排
- 正确示例:
element.classList.add('new-style'); // 批量修改
- 批量修改样式:使用
2. 减少 DOM 操作
- 使用文档碎片(Document Fragment):将多次 DOM 修改合并为一次操作。
const fragment = document.createDocumentFragment(); data.forEach(item => {const li = document.createElement('li');li.textContent = item;fragment.appendChild(li); }); ul.appendChild(fragment);
- 避免频繁操作内联样式:优先通过 CSS 类名控制样式。
3. 优化动画与合成
- 使用
requestAnimationFrame
:将动画操作绑定到浏览器的刷新周期,避免丢帧。let progress = 0; function animate() {progress += 1;element.style.transform = `translateX(${progress}px)`;if (progress < 100) requestAnimationFrame(animate); } requestAnimationFrame(animate);
- 利用 CSS 合成层:对频繁动画的元素设置
will-change: transform
或transform: translateZ(0)
,使其单独成为一个合成层,减少重绘影响。
四、网络加载优化
1. 代码压缩与 Tree Shaking
- 工具:使用 Webpack、Rollup 等打包工具压缩代码,移除未使用的代码(Tree Shaking,需配合 ES6 模块)。
2. 按需加载与懒加载
- 按需加载:通过动态导入(
import('./module.js')
)实现路由或组件的异步加载。 - 懒加载:对非关键资源(如图片、非首屏脚本)延迟加载,使用
Intersection Observer
监听元素进入视口。
3. 缓存策略
- 使用
localStorage
/sessionStorage
:缓存频繁访问的数据(如用户配置)。 - HTTP 缓存:设置
Cache-Control
头,合理利用浏览器缓存静态资源。
五、其他优化技巧
1. 避免 eval() 和 with 语句
- 原因:
eval()
会阻塞 JavaScript 引擎优化,with
会导致作用域链变长,影响性能。
2. 使用高效的数据结构
- 场景:
- 频繁查找:用
Map
替代对象(键可非字符串,且遍历性能更优)。 - 有序数据:用
Array
或Set
(去重场景)。
- 频繁查找:用
3. 性能监控与分析
- 工具:
- 浏览器 DevTools(Performance 面板录制性能分析)。
- Lighthouse 审计性能指标(如 FCP、LCP、TTI 等)。
总结
性能优化需遵循“过早优化是万恶之源”原则,优先通过 profiling 定位瓶颈,再针对性优化。核心思路包括:减少计算量、降低内存占用、优化渲染流程、提升资源加载效率。实际项目中可结合框架特性(如 React 的 useMemo
/useCallback
、Vue 的 v-show
/v-if
合理使用)进一步提升性能。
性能优化之vue3
在 Vue3 中,性能优化需结合 Composition API、响应式原理和渲染机制进行针对性处理。以下从代码结构、响应式优化、渲染效率等角度提供实例和避坑指南:
一、响应式系统优化
1. 避免过度响应式
问题场景:将大型静态数据(如常量配置、初始表单值)放入响应式对象会增加不必要的依赖追踪开销。
优化方案:
- 使用
readonly
包装静态数据 - 使用普通 JS 对象存储无需响应式的数据
import { ref, readonly } from 'vue'// 错误示例:将常量配置转为响应式
const config = reactive({API_URL: 'https://api.example.com',MAX_FILE_SIZE: 1024
})// 正确示例:使用 readonly 包装静态数据
const config = readonly({API_URL: 'https://api.example.com',MAX_FILE_SIZE: 1024
})// 正确示例:表单初始值使用普通对象
const initialFormData = {name: '',age: 0
}
const formData = ref({ ...initialFormData })
2. 局部响应式替代全局响应式
问题场景:在组件中使用 reactive
创建大型对象时,所有属性都会被递归转为响应式,导致性能开销。
优化方案:
- 使用
ref
替代reactive
存储复杂结构 - 对无需响应式的深层属性使用
shallowReactive
/shallowRef
import { ref, shallowReactive } from 'vue'// 错误示例:递归响应式大型对象
const tableData = reactive({list: [], // 可能包含大量数据pagination: { page: 1, size: 10 }
})// 正确示例:仅表层响应式
const tableData = shallowReactive({list: ref([]), // 列表数据变化时手动更新pagination: { page: 1, size: 10 }
})
二、组件设计优化
1. 使用 v-once
缓存静态内容
适用场景:包含大量静态内容的组件(如介绍文案、帮助信息)
<template><div><!-- 静态内容只需渲染一次 --><div v-once class="static-content"><h1>关于我们</h1><p>公司简介:...(大量静态文本)</p></div><!-- 动态内容正常渲染 --><div class="dynamic-content"><p>当前时间:{{ currentTime }}</p></div></div>
</template>
2. 使用 v-memo
缓存重复渲染的列表项
适用场景:列表项中大部分数据不变,仅少量字段变化
<template><div><!-- 仅当 item.id 或 item.name 变化时才重新渲染 --><div v-for="item in list" v-memo="[item.id, item.name]" :key="item.id"><span>{{ item.name }}</span><span>{{ expensiveComputation(item) }}</span> <!-- 复杂计算 --></div></div>
</template>
3. 组件懒加载与 Suspense
适用场景:非首屏组件(如模态框、详情页)
<template><div><button @click="showDetail = true">查看详情</button><!-- 按需加载详情组件 --><Suspense v-if="showDetail"><template #default><LazyDetailComponent :id="itemId" /></template><template #fallback><div>加载中...</div></template></Suspense></div>
</template><script setup>
import { ref } from 'vue'// 懒加载组件
const LazyDetailComponent = defineAsyncComponent(() => import('./DetailComponent.vue'))const showDetail = ref(false)
const itemId = ref(1)
</script>
三、渲染与更新优化
1. 避免不必要的 watch
问题场景:监听大型对象导致频繁触发回调
优化方案:
- 监听特定属性而非整个对象
- 使用
deep: true
时结合immediate: false
避免初始触发
import { watch } from 'vue'const formData = ref({name: '',age: 0,address: {city: '',street: ''}
})// 错误示例:监听整个对象
watch(formData, (newVal) => {// 每次任何属性变化都会触发
})// 正确示例:监听特定属性
watch(() => formData.value.name, (newName) => {// 仅 name 变化时触发
})// 正确示例:深度监听(仅在必要时使用)
watch(() => formData.value.address, (newAddress) => { /* ... */ },{ deep: true, immediate: false }
)
2. 优化计算属性
问题场景:复杂计算属性未缓存结果,导致重复计算
优化方案:
- 确保计算属性纯函数化
- 对耗时计算使用缓存策略
import { computed } from 'vue'const list = ref([1, 2, 3, 4, 5])// 错误示例:包含副作用的计算属性
const filteredList = computed(() => {console.log('计算中...') // 每次访问都会执行return list.value.filter(item => item > 3)
})// 正确示例:纯函数计算属性
const filteredList = computed(() => list.value.filter(item => item > 3))// 复杂计算的缓存优化
const expensiveResult = computed(() => {// 使用 WeakMap 缓存计算结果const cache = new WeakMap()if (cache.has(list.value)) {return cache.get(list.value)}const result = /* 复杂计算逻辑 */cache.set(list.value, result)return result
})
四、事件处理优化
1. 防抖/节流处理高频事件
适用场景:搜索联想、滚动加载、窗口大小变化
<template><div><input v-model="searchText" @input="debouncedSearch" /></div>
</template><script setup>
import { ref } from 'vue'
import { debounce } from 'lodash-es' // 或自定义防抖函数const searchText = ref('')// 创建防抖函数
const debouncedSearch = debounce((value) => {fetchData(value) // 执行搜索请求
}, 300)
</script>
2. 避免在循环中绑定复杂事件处理函数
问题场景:大型列表中每个项都绑定复杂事件处理函数
优化方案:
- 使用事件委托
- 将事件处理函数提取到组件外部
<template><!-- 错误示例:每个项都创建新的处理函数 --><ul><li v-for="item in list" :key="item.id" @click="() => handleClick(item)">{{ item.name }}</li></ul><!-- 正确示例:事件委托 --><ul @click="handleListClick"><li v-for="item in list" :key="item.id" :data-id="item.id">{{ item.name }}</li></ul>
</template><script setup>
import { ref } from 'vue'const list = ref([...])// 事件委托处理函数
const handleListClick = (event) => {const targetId = event.target.closest('li').dataset.idif (targetId) {// 处理点击逻辑}
}
</script>
五、内存管理优化
1. 手动清理副作用
问题场景:定时器、WebSocket、自定义事件未清理导致内存泄漏
优化方案:
- 在
onUnmounted
钩子中清理副作用 - 使用
watch
的停止函数
import { onUnmounted, watch } from 'vue'// 定时器示例
let timer = nullconst setupTimer = () => {timer = setInterval(() => {// 定时任务}, 1000)
}// 组件卸载时清理
onUnmounted(() => {clearInterval(timer)
})// watch 停止函数示例
const stop = watch(source, (newVal) => {// 监听逻辑
})// 手动停止监听
stop()
2. 避免组件间循环引用
问题场景:父组件引用子组件,子组件又引用父组件
优化方案:
- 通过事件或状态管理(如 Pinia)解耦组件通信
- 使用
provide/inject
替代直接引用
// 错误示例:父子组件循环引用
// Parent.vue
import Child from './Child.vue'// Child.vue
import Parent from './Parent.vue'// 正确示例:使用事件通信
// Parent.vue
<Child @custom-event="handleEvent" />// Child.vue
const emit = defineEmits(['custom-event'])
emit('custom-event', data)
六、构建与部署优化
1. 代码分割与按需加载
配置方案:在 Vite/Webpack 中配置动态导入
// router.js
const routes = [{path: '/dashboard',name: 'Dashboard',// 动态导入组件component: () => import('../views/Dashboard.vue')}
]
2. 使用生产模式构建
优化效果:
- 移除开发环境代码(如
console.log
、process.env.NODE_ENV
判断) - 压缩混淆代码
- 启用 Tree Shaking
# Vite 构建命令
npm run build -- --mode production
性能优化检查清单
-
响应式检查:
- 是否将大型静态数据转为响应式?
- 是否使用
shallowReactive
避免深层响应式?
-
渲染效率检查:
- 是否使用
v-once
缓存静态内容? - 是否使用
v-memo
优化列表渲染? - 是否有不必要的组件重新渲染?
- 是否使用
-
内存管理检查:
- 是否清理了所有定时器和事件监听器?
- 是否存在组件间循环引用?
-
构建优化检查:
- 是否按需加载非首屏组件?
- 是否使用生产模式构建?
通过以上优化手段,可有效提升 Vue3 应用的性能表现。建议结合浏览器 DevTools 的 Performance 面板进行性能分析,针对性地解决瓶颈问题。
相关文章:
浅谈 JavaScript 性能优化
文章目录 概要一、代码执行优化1. 减少全局变量访问2. 避免不必要的计算3. 优化循环操作 二、内存管理优化1. 减少内存泄漏2. 对象池与内存复用 三、渲染性能优化1. 避免强制同步布局2. 减少 DOM 操作3. 优化动画与合成 四、网络加载优化1. 代码压缩与 Tree Shaking2. 按需加载…...
React从基础入门到高级实战:React 生态与工具 - 构建与部署
React 构建与部署 引言 在现代Web开发中,构建与部署是项目从开发到上线的关键环节。对于React开发者而言,掌握构建优化和部署策略不仅能提升应用的性能,还能确保项目的稳定性和安全性。随着React应用的复杂性不断增加,合理的构建…...

Kafka性能调优三剑客:深度解析buffer_memory、linger_ms和batch_size
💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 持续学习,不断…...

5分钟学会网络服务搭建,飞凌i.MX9352 + Linux 6.1实战示例
在“万物互联”的技术浪潮下,网络服务已成为连接物理世界与数字世界的核心纽带,它不仅赋予了终端设备“开口说话”的能力,更构建了智能设备的开发范式。 本文就将以飞凌嵌入式OK-MX9352-C开发板(搭载了在工业物联网领域广泛应用的…...

网络安全-等级保护(等保) 3-2-2 GB/T 28449-2019 第7章 现场测评活动/第8章 报告编制活动
################################################################################ GB/T 28449-2019《信息安全技术 网络安全等级保护测评过程指南》是规定了等级测评过程,是纵向的流程,包括:四个基本测评活动:测评准备活动、方案编制活…...
74道TypeScript高频题整理(附答案背诵版)
1.简述什么是TypeScript ? TypeScript是一种由Microsoft开发和维护的开源编程语言。它是JavaScript的一个超集,意味着它扩展了JavaScript的功能,包括添加了类型系统和对ES6的新特性的支持。TypeScript的设计目标是帮助开发者捕捉代码中的错误…...
PostgreSQL 临时表空间
PostgreSQL 临时表空间 PostgreSQL 使用临时表空间来存储查询执行过程中产生的临时数据,与 Oracle 类似但实现方式有所不同。 一、临时表空间基本概念 PostgreSQL 的临时表空间主要用于存储: 排序操作(ORDER BY、GROUP BY、DISTINCT&…...
N2语法 状態
1,~てならない 接続:て型 意味:…得不得了(强调自然产生的情感,可接自发动词) 例文: お腹が痛くてならない。 心配でならない。 両親に会いたくてならない。(非常…...

从Node.js到Go:如何从NestJS丝滑切换并爱上Sponge框架
引言 各位 NestJS 老司机们, 不得不说,用装饰器开发 API 简直像在键盘上跳华尔兹——Controller 转个圈,Get 踮个脚,Injectable 优雅谢幕,三下五除二就能搭出个像模像样的后端服务。TypeScript 的类型检查就像个贴心管…...

海思 35XX MIPI读取YUV422
1.项目背景: 使用海思芯片,接收FPGA发送的MIPI数据,不需要ISP处理,YUV图像格式为YUV422。 2.移植MIPI驱动 修改IMX347的驱动远吗,将I2C读写的部分注释,其他的不用再做修改。 int imx347_slave_i2c_init(ot…...
sass三大循环语法
for for 指令可以在限制的范围内重复输出格式,每次按要求(变量的值)对输出结果做出变动。这个指令包含两种格式:for $var from through ,或者 for v a r f r o m < s t a r t > t o < e n d > ÿ…...

第1章 Redis 概述
一、Redis 简介 Redis,Remote Dictionary Server,远程字典服务,由意大利人Salvatore Sanfilippo(又名Antirez)开发,是一个使用ANSI C 语言编写、支持网络、 可基于内存亦可持久化的日志型、NoSQL 开源内存数据库,其提供多种语言的API。…...

硬件工程师笔记——二极管Multisim电路仿真实验汇总
目录 1 二极管基础知识 1.1 工作原理 1.2 二极管的结构 1.3 PN结的形成 1.4 二极管的工作原理详解 正向偏置 反向偏置 multisim使用说明链接 2 二极管特性实验 2.1 二极管加正向电压 2.2 二极管加反向电压 2.3 二极管两端的电阻 2.4 交流电下二级管工作 2.5 二极…...

30V/3A,云岑CP8335B,完美替换EUP3484
1 FEATURES ● Wide Input Voltage Range: 6V ~ 30V ● Low RDS(ON) for Internal Switches (Top/Bottom): 90mΩ/65 mΩ ● 3A output current capability ● 500kHz Switching Frequency Minimize the External Components ● Internal 1.5-ms Soft-Start ● 0.6V/0.8V/0.925…...
基于大模型预测的FicatIII-IV期股骨头坏死综合治疗研究报告
目录 一、引言 1.1 研究背景与目的 1.2 国内外研究现状 1.3 研究意义和创新点 二、FicatIII-IV 期股骨头坏死概述 2.1 疾病定义与分期 2.2 病因与病理机制 2.3 临床症状与诊断方法 三、大模型预测原理与方法 3.1 大模型简介 3.2 数据收集与预处理 3.3 模型训练与优…...
promptfoo:让语言模型评测不再“靠感觉”——一站式 LLM 自动化测评神器深度解读
大家好,这里是你们喜闻乐见、永远不低调的 AI 技术博主。这篇分享,我要隆重介绍一个我愿称之为“LLM 测试自动化福音”的神器——promptfoo。 如果你做 LLM(大模型)落地开发,调教 prompt 拼死拼活,一上线用…...

LINUX安装运行jeelowcode后端项目(idea启动)
参考 LINUX安装运行jeelowcode后端项目(命令行)-CSDN博客 IntelliJ IDEA下载地址(社区版、付费版)-CSDN博客 软件已安装好,数据库也初始化完毕。 步骤1:打开项目目录步骤2:配置JDK步骤3&…...

硬件I2C和软件I2C的区别
硬件I2C和软件I2C的区别 一、硬件I2C 1、硬件IC的局限性及学习意义 尽管硬件IC外设在STM32等微控制器中提供了标准化的通信支持,但在实际应用中,其稳定性可能存在问题。例如,某些情况下外设会因事件检测异常而进入死锁状态,仅能…...
单元测试报错
报错信息如下所示: 五月 30, 2025 5:35:44 下午 org.junit.vintage.engine.descriptor.RunnerTestDescriptor warnAboutUnfilterableRunner 警告: Runner org.junit.internal.runners.ErrorReportingRunner (used on class redis.demo.RedisTemplateTest) does not…...

AWS WAF设置IP白名单
目标 设置一个组白名单IP地址,当发现是这些IP地址发过来的请求后,WAF自动放行。 创建IP集 打开WAF页面,开始IP集创建如下图: 设置ip集,如下图: aws waf acl配置白名单 找到Web ACL,开始在…...

智能门禁的项目
项目需求 矩阵键盘输入密码,正确开锁,错误提示,三次错误后蜂鸣器响三秒;按下#号确认输入,按下*号修改密码;密码保存在W25Q128里;OLED屏幕显示信息。 硬件清单 矩阵键盘OLED显示屏继电器蜂鸣器…...

《Google I/O 2025:AI浪潮下的科技革新风暴》
Google I/O 2025 盛大开幕 在科技飞速发展的时代,Google I/O 开发者大会一直是全球科技爱好者和开发者瞩目的焦点,堪称科技领域的年度盛宴。2025 年 5 月 20 日至 21 日,Google I/O 2025 在美国加州山景城的 Shoreline Amphitheatre 盛大举行…...

职坐标IT培训:硬件嵌入式与AI芯片开发实战
课程体系以硬件嵌入式开发与AI芯片技术融合为核心,构建模块化知识框架。从硬件设计规范切入,系统讲解PCB Layout设计中的信号完整性控制、电磁兼容性(EMC)优化等关键要素,延伸至高速电路设计中阻抗匹配与电源完整性&am…...

一句话开发Chrome摸鱼插件
本文所使用的 CodeBuddy 免费下载链接:腾讯云代码助手 CodeBuddy - AI 时代的智能编程伙伴。 CodeBuddy 一、CodeBuddy新功能特色 Craft智能体:自然语言驱动的全栈开发引擎Craft开发智能体的核心突破在于实现需求理解-任务拆解-代码生成的…...

Spring Boot + OpenCSV 数据清洗实战:CSV 结构化处理与可视化
目录 摘要 演示 一、背景:为什么需要自动化数据清洗? 二、技术选型:为什么选择这三个工具? 三、核心功能实现:从数据读取到智能清洗 1. 配置控制器 2. 文件上传控制器 3. CSV数据处理服务接口 4. CSV数据处理…...

Cmake编译glog成功并在QT中测试成功步骤
glog是开源的日志记录系统,下载地址GitHub - google/glog: C implementation of the Google logging module 跟gflags有点相似,编译和测试过程比较周折,所以记录下来具体的编译和测试步骤。 编译环境:WindowsCmakeVs2022Qt5.14.…...
AI绘画提示词:从零开始掌握Prompt Engineering的艺术
文章目录 什么是AI绘画提示词?提示词的基本结构主体描述场景/背景风格指定技术参数负面提示人物肖像模板风景模板 高级技巧权重调整混合风格颜色控制情绪氛围 常见问题与解决方法手部变形问题构图不理想风格不够突出 提示词示例库科幻场景奇幻人物静物画 结语 在当今…...

xhr、fetch和axios
XMLHttpRequest (XHR) XMLHttpRequest 是最早用于在浏览器中进行异步网络请求的 API。它允许网页在不刷新整个页面的情况下与服务器交换数据。 // 创建 XHR 对象 const xhr new XMLHttpRequest();// 初始化请求 xhr.open(GET, https://api.example.com/data, true);// 设置请…...
lcd-framebuffer驱动开发参考文章
MMAP mmap的时候总是失败,查了很多资料,显存大小是驱动层fb_info->fix.smem_len设置,要遵循内核页大小的整数倍,应用层调用mmap也要遵循对齐。 MMAP使用(一、基本接口)_mmap接口-CSDN博客 基于fbtft和…...

2025吉林ccpc【部分题解】
文章目录 C - SSPPSPSPProblemD.互互互质质质ProblemF. Ever ForeverProblemG.石石石头头头剪剪剪刀刀刀布布布Problem J.奇偶游戏Problem L.好矩阵 C - SSPPSPSP 题目来源:C - SSPPSPSP !](https://i-blog.csdnimg.cn/direct/26fc1492b1724446be61cf39b718cf9b.…...