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

Webpack中Compiler详解以及自定义loader和plugin详解

Webpack Compiler 源码全面解析

Compiler

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

类图解析:

1. Tapable 基类

Webpack 插件系统的核心,提供钩子注册(plugin)和触发(applyPlugins)能力。CompilerCompilation 均继承此类,支持插件通过生命周期钩子介入构建流程。

2. Compiler 类

在这里插入图片描述
在这里插入图片描述

• 核心属性

 ◦ `options`:整合 Webpack 配置(入口、出口、Loader 等)  ◦ `hooks`:包含 `run`(构建启动)、`compile`(编译开始)、`emit`(资源生成前)等钩子,插件可监听这些事件  

• 核心方法

 ◦ `run()`:启动构建流程,触发 `beforeRun` 和 `run` 钩子  ◦ `compile()`:创建 `Compilation` 实例,进入模块解析阶段

3. Compilation 类

在这里插入图片描述

• 核心属性

 ◦ `modules`:所有被处理的模块集合,包含源码和依赖信息  ◦ `chunks`:代码分块(如通过 `SplitChunksPlugin` 分割的公共模块)  ◦ `assets`:最终输出的文件内容(如 JS、CSS、图片等)  

• 核心方法

 ◦ `addEntry()`:从入口文件递归分析依赖,构建模块依赖图  ◦ `seal()`:冻结依赖图,执行 Tree Shaking 和代码压缩等优化  ◦ `emitAsset()`:将资源写入磁盘,触发 `emit` 钩子

4 协作关系

• 生命周期:Compiler 管理全局构建流程(如初始化配置、触发钩子),而 Compilation 负责单次编译的具体实现(模块解析、优化、输出)

• 实例化:每次构建(包括开发模式下文件变化)时,Compiler 会创建新的 Compilation 实例,确保资源状态隔离。

应用场景示例:
• 插件开发:通过监听 Compiler.hooks.emit 修改输出内容(如删除注释)

• 性能优化:利用 Compilation.modules 分析模块体积,实现按需加载。

在这里插入图片描述


在前端工程化中,自定义 Webpack 的 Loader 和 Plugin 是扩展构建流程的核心能力。以下从实现原理、开发步骤、典型场景等维度深入解析两者的设计与应用:


自定义loader和plugin

一、自定义 Loader 的实现

1. 核心原理与开发步骤

• 本质与作用

Loader 是文件转换器,将非 JS 文件(如 Markdown、CSS)转换为 Webpack 可处理的模块。其开发需遵循单一职责原则,且需保持无状态。

• 实现步骤:

  1. 创建函数:导出一个处理文件内容的函数,接收 source(文件内容)作为输入。
  2. 处理内容:通过正则或工具库(如 markedbabel)对内容转换,例如将 Markdown 转 HTML。
  3. 返回结果:需返回 JS 代码字符串,支持 module.exports 或 ES Modules 导出。
  4. 配置使用:在 webpack.config.jsmodule.rules 中通过 test 匹配文件类型并串联 Loader。
2. 同步与异步 Loader

• 同步处理:直接返回结果,适用于简单转换(如字符串替换)。

module.exports = function (content) {return content.replace(/world/g, 'loader'); // 替换文本
};

• 异步处理:通过 this.async() 实现异步操作(如网络请求、文件读取)。

module.exports = function (content) {const callback = this.async();fetchData().then(() => callback(null, processedContent));
};
3. 典型场景示例

• 多语言翻译:替换代码中的 __t('KEY') 为对应语言字符串。

• 资源优化:使用 svgo 压缩 SVG 文件,或通过 imagemin 生成 WebP 图片。

• 语法转换:自定义 Babel Loader 实现 ES6 转 ES5。


二、自定义 Plugin 的实现

在这里插入图片描述

1. 核心机制与生命周期

• 实现原理:

Plugin 通过监听 Webpack 生命周期钩子(如 emitdone)介入构建流程,操作 compilercompilation 对象。

• 开发步骤:

  1. 创建类:定义包含 apply 方法的类,接收 compiler 对象。
  2. 注册钩子:在目标钩子(如 emit)中挂载逻辑,操作资源或生成附加文件。
  3. 配置使用:在 plugins 数组中实例化插件。
2. 典型场景示例

• 打包报告生成:在 done 钩子中生成包含构建时间、模块大小的 JSON 报告。

• 资源修改:在 emit 阶段遍历 compilation.assets,删除 JS 注释或修改文件内容。

compiler.hooks.emit.tap('MyPlugin', (compilation) => {Object.keys(compilation.assets).forEach(name => {if (name.endsWith('.js')) {const content = compilation.assets[name].source().replace(/\/\*.*?\*\//g, '');compilation.assets[name] = { source: () => content, size: () => content.length };}});
});

• 自动化注入:类似 HtmlWebpackPlugin,动态生成 HTML 并插入脚本。

3. 高级应用

• 自定义钩子:通过 tapable 创建同步/异步钩子,扩展插件间的通信能力。

• 多插件协作:结合其他插件(如 CleanWebpackPlugin)清理构建目录。


三、Loader 与 Plugin 的协同与对比

维度LoaderPlugin
作用层级单文件处理(如转译、压缩)全局流程控制(如资源优化、报告生成)
执行时机模块加载阶段任意构建阶段(通过钩子介入)
配置方式module.rules 中定义规则链plugins 数组实例化
典型工具babel-loadercss-loaderHtmlWebpackPluginTerserPlugin

四、调试与优化建议

  1. Loader 调试
    • 使用 loader-runner 独立测试逻辑。

    • 通过 this.getOptions() 获取配置参数,结合 schema.json 校验参数合法性。

  2. Plugin 性能优化
    • 在 afterEmit 阶段执行耗时操作,避免阻塞主流程。

    • 利用 compilation.fileTimestamps 缓存文件修改时间,减少重复处理。


五、总结

自定义 Loader 和 Plugin 是 Webpack 生态灵活性的核心体现。Loader 聚焦于文件级转换,适合语法兼容、资源预处理等场景;Plugin 则通过生命周期钩子实现全局控制,适用于构建优化、自动化注入等复杂需求。两者的协同使用可覆盖从模块处理到工程化优化的全链路需求,开发者可根据具体场景选择合适方案。


  1. 自定义 Loader:将 Markdown 转换为 HTML。
  2. 自定义 Plugin:构建结束发送通知(以控制台模拟为例,实际可扩展为系统通知)。
  3. 自定义 Plugin:构建时检测重复依赖并输出警告。

样例

🔧 1. 自定义 Markdown 转 HTML Loader

依赖:安装 marked(或 markdown-it

npm install marked --save-dev
loaders/md-to-html-loader.js
const marked = require('marked');module.exports = function (source) {const html = marked(source);// 返回一段 JS 模块代码,导出 HTML 字符串return `export default ${JSON.stringify(html)}`;
};
webpack.config.js 中配置:
module.exports = {module: {rules: [{test: /\.md$/,use: path.resolve(__dirname, 'loaders/md-to-html-loader.js')}]}
};

🔔 2. 自定义构建结束发送通知 Plugin

控制台通知实现(也可以结合 node-notifier 发桌面通知)

plugins/build-notifier-plugin.js
class BuildNotifierPlugin {apply(compiler) {compiler.hooks.done.tap('BuildNotifierPlugin', (stats) => {const time = (stats.endTime - stats.startTime) / 1000;console.log(`✅ 构建完成!耗时 ${time.toFixed(2)}`);});}
}module.exports = BuildNotifierPlugin;
webpack.config.js 中配置:
const BuildNotifierPlugin = require('./plugins/build-notifier-plugin');module.exports = {plugins: [new BuildNotifierPlugin()]
};

可选增强:使用 node-notifier 发系统弹窗提示。


🧩 3. 自定义重复依赖检测 Plugin

这个插件会分析所有模块中使用的依赖包并查找是否存在多个版本的情况(如多个 lodash)

plugins/duplicate-dependency-plugin.js
const path = require('path');
const fs = require('fs');class DuplicateDependencyPlugin {apply(compiler) {compiler.hooks.emit.tapAsync('DuplicateDependencyPlugin', (compilation, callback) => {const moduleVersions = {};compilation.modules.forEach((module) => {if (module.resource && module.resource.includes('node_modules')) {const parts = module.resource.split('node_modules' + path.sep);if (parts[1]) {const pkgPath = parts[1].split(path.sep);const name = pkgPath[0].startsWith('@') ? `${pkgPath[0]}/${pkgPath[1]}` : pkgPath[0];const packageJsonPath = path.join(module.resource.split('node_modules')[0], 'node_modules', name, 'package.json');try {const pkg = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));if (!moduleVersions[name]) {moduleVersions[name] = new Set();}moduleVersions[name].add(pkg.version);} catch (err) {// 忽略找不到 package.json 的模块}}}});// 输出重复依赖警告Object.entries(moduleVersions).forEach(([name, versions]) => {if (versions.size > 1) {console.warn(`⚠️ 发现重复依赖:${name},版本有:${[...versions].join(', ')}`);}});callback();});}
}module.exports = DuplicateDependencyPlugin;
webpack.config.js 中配置:
const DuplicateDependencyPlugin = require('./plugins/duplicate-dependency-plugin');module.exports = {plugins: [new DuplicateDependencyPlugin()]
};

📦 最终项目结构参考

webpack-project/
├── loaders/
│   └── md-to-html-loader.js
├── plugins/
│   ├── build-notifier-plugin.js
│   └── duplicate-dependency-plugin.js
├── src/
│   └── index.js
├── content/
│   └── example.md
├── webpack.config.js
└── package.json

相关文章:

Webpack中Compiler详解以及自定义loader和plugin详解

Webpack Compiler 源码全面解析 Compiler 类图解析: 1. Tapable 基类 Webpack 插件系统的核心,提供钩子注册(plugin)和触发(applyPlugins)能力。Compiler 和 Compilation 均继承此类,支持插件…...

deepseek-coder-6.7b-instruct安装与体验-success

目录 步骤1:安装环境 步骤2:下载模型 步骤3:安装依赖 步骤4:运行模型 报错NameError: name torch is not defined 步骤5:运行结果 步骤1:安装环境 pip install modelscope 步骤2:下载模型 modelscope download --model deepseek-ai/deepseek-coder-6.7b-instruct --lo…...

对抗进行性核上性麻痹,健康护理筑牢生活防线

进行性核上性麻痹是一种复杂的神经退行性疾病,主要影响患者的运动、平衡及吞咽等功能,随着病情进展,患者生活质量会受到严重影响。除规范治疗外,科学的健康护理是提高患者生活质量、延缓病情发展的重要手段。 日常活动护理是基础。…...

科学养生,拥抱健康生活

在生活节奏日益加快的今天,养生不再是遥不可及的概念,而是可以融入日常的健康生活方式。即使抛开中医理念,通过科学的生活方式选择,也能为身体注入源源不断的活力。 从营养管理开始,构建科学的饮食体系。采用 “321 饮…...

基于若依框架的岗位名称查询模块实现

表名:sys_post(若依自带的一个表) 目标:获取post_name中所有的名字 模块结构说明 src/ ├── main/ │ ├── java/ │ │ └── com/ │ │ └── ruoyi/ │ │ └── nametraversal/ │ │…...

(2)Python爬虫--requests

文章目录 前言一、 认识requests库1.1 前情回顾1.2 为什么要学习requests库1.3 requests库的基本使用1.4 响应的保存1.5 requests常用的方法1.6 用户代理1.7 requests库:构建ua池(可以先跳过去)1.8 requests库:带单个参数的get请求1.9 requests库&#x…...

springboot旅游小程序-计算机毕业设计源码76696

目 录 摘要 1 绪论 1.1研究背景与意义 1.2研究现状 1.3论文结构与章节安排 2 基于微信小程序旅游网站系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能性分析 2.3 系统…...

TCPIP详解 卷1协议 七 防火墙和网络地址转换

7.1——防火墙和网络地址转换 为防止终端系统不被攻击,需要一种方法来控制互联网中网络流量的流向。这项工作由防火墙来完成,它是一种能够限制所转发的流量类型的路由器。 随着部署防火墙来保护企业,另一个问题变得越来越重要:可…...

Golang 应用的 CI/CD 与 K8S 自动化部署全流程指南

一、CI/CD 流程设计与工具选择 1. 技术栈选择 版本控制:Git(推荐 GitHub/GitLab)CI 工具:Jenkins/GitLab CI/GitHub Actions(本文以 GitHub Actions 为例)容器化:Docker Docker Compose制品库…...

Jenkins:库博静态工具CI/CD 的卓越之选

在当今快节奏的软件开发领域,高效的持续集成(CI)和持续交付(CD)流程对于项目的成功至关重要。Jenkins 作为开源 CI/CD 软件的领导者,以其强大的功能、丰富的插件生态和高度的可扩展性,成为众多开…...

Maven私服搭建与登录全攻略

目录 1.背景2.简介3.安装4.启动总结参考文献 1.背景 回顾下maven的构建流程,如果没有私服,我们所需的所有jar包都需要通过maven的中央仓库或者第三方的maven仓库下载到本地,当一个公司或者一个团队所有人都重复的从maven仓库下载jar包&#…...

大模型数据分析破局之路20250512

大模型数据分析破局之路 本文面向 AI 初学者、数据分析从业者与企业技术负责人,围绕大模型如何为数据分析带来范式转变展开,从传统数据分析困境谈起,延伸到 LLM MCP 的协同突破,最终落脚在企业实践建议。 🌍 开篇导语…...

数据结构-树(1)

一、树的基本概念 二&#xff0c;树的抽象数据结构 三&#xff0c;树的存储结构 1.双亲表示法 数组存储结点&#xff0c;含数据域和双亲下标&#xff08;根结点双亲为 - 1&#xff09; 代码示例 include <stdio.h> #include <stdlib.h>#define MAX_TREE_SIZE 10…...

什么是ERP?ERP有哪些功能?小微企业ERP系统源码,SpringBoot+Vue+ElementUI+UniAPP

什么是ERP&#xff1f; ERP翻译过来叫企业资源计划&#xff0c;通俗的讲&#xff0c;应该叫企业的全面预算控制&#xff0c;其通常包括三个部分&#xff1a;工程预算、投资预算和经营预算&#xff08;即产销存预算&#xff09;。之所以做预算控制&#xff0c;是因为企业运作的…...

视觉-语言-动作模型:概念、进展、应用与挑战(上)

25年5月来自 Cornell 大学、香港科大和希腊 U Peloponnese 的论文“Vision-Language-Action Models: Concepts, Progress, Applications and Challenges”。 视觉-语言-动作 (VLA) 模型标志着人工智能的变革性进步&#xff0c;旨在将感知、自然语言理解和具体动作统一在一个计…...

C++ 与 Go、Rust、C#:基于实践场景的语言特性对比

目录 ​编辑 一、语法特性对比 1.1 变量声明与数据类型 1.2 函数与控制流 1.3 面向对象特性 二、性能表现对比​编辑 2.1 基准测试数据 在计算密集型任务&#xff08;如 10⁷ 次加法运算&#xff09;中&#xff1a; 在内存分配测试&#xff08;10⁵ 次对象创建&#xf…...

RDB和AOF的区别

Redis提供两种主要的持久化机制&#xff1a;RDB&#xff08;Redis Database&#xff09;和AOF&#xff08;Append Only File&#xff09;&#xff0c;它们在数据持久化方式、性能影响及恢复策略上各有特点。以下是两者的对比分析及使用建议&#xff1a; RDB&#xff08;快照持久…...

因子分析基础指南:原理、步骤与地球化学数据分析应用解析

前言 在看深度学习成矿预测以及地球化学数据分析的文献的时候很多引言部分的内容会提到一些老的技术&#xff0c;正所谓&#xff1a;知其然知其所以然。所以我把关于一些老技术的基础铺垫的内容作为&#xff1a;研究生基础指南部分进行记录。 这部分讲述的是因子分析&#xf…...

采用AI神经网络降噪算法的通信语音降噪(ENC)模组性能测试和应用

采用AI降噪的语言通话环境抑制模组性能效果测试 随着AI时代来临.通话设备的环境噪音抑制也进入AI降噪算法时代. AI神经网络降噪技术是一款革命性的语音处理技术&#xff0c;他突破了传统单麦克风和双麦克风降噪的局限性,利用采集的各种日常环境中的噪音样本进行训练学习.让降噪…...

面试题 - Kafka、RabbitMQ、RocketMQ如何选型?

在当今的高并发、大数据时代&#xff0c;系统架构的复杂性呈指数级增长。你是否曾遇到过这样的问题&#xff1a;用户订单提交后&#xff0c;系统响应缓慢甚至卡顿&#xff1f;或者在业务高峰期&#xff0c;消息积压导致系统崩溃&#xff1f; 这些问题的背后&#xff0c;往往隐…...

【落羽的落羽 C++】stack和queue、deque、priority_queue、仿函数

文章目录 一、stack和queue1. 概述2. 使用3. 模拟实现 二、deque三、priority_queue1. 概述和使用2. 模拟实现 四、仿函数 一、stack和queue 1. 概述 我们之前学习的vector和list&#xff0c;以及下面要认识的deque&#xff0c;都属于STL的容器&#xff08;containers&#x…...

Golang 空结构体特性与用法

文章目录 1.简介2.核心特性2.1 零内存占用2.2 值比较语义2.3 类型隔离2.4 值地址 3.作用3.1 实现集合&#xff08;Set&#xff09;3.2 不发送数据的信道3.3 无状态方法接收者3.4 作为 context 的 value 的 key 4.小结参考文献 1.简介 在 Go 语言中&#xff0c;空结构体是一个不…...

企业对数据集成工具的需求及 ETL 工具工作原理详解

当下&#xff0c;数据已然成为企业运营发展过程中的关键生产要素&#xff0c;其重要性不言而喻。 海量的数据分散在企业的各类系统、平台以及不同的业务部门之中&#xff0c;企业要充分挖掘这些数据背后所蕴含的巨大价值&#xff0c;实现数据驱动的精准决策&#xff0c;数据集…...

基于HTTP头部字段的SQL注入:SQLi-labs第17-20关

前置知识&#xff1a;HTTP头部介绍 HTTP&#xff08;超文本传输协议&#xff09;头部&#xff08;Headers&#xff09;是客户端和服务器在通信时传递的元数据&#xff0c;用于控制请求和响应的行为、传递附加信息或定义内容类型等。它们分为请求头&#xff08;Request Headers&…...

Megatron系列——流水线并行

内容总结自&#xff1a;bilibili zomi 视频大模型流水线并行 注&#xff1a;这里PipeDream 1F1B对应时PP&#xff0c;Interleaved 1F1B对应的是VPP 1、朴素流水线并行 备注&#xff1a; &#xff08;1&#xff09;红色三个圈都为空泡时间&#xff0c;GPU没有做任何计算 &am…...

Android HttpAPI通信问题(待解决)

使用ClearTextTraffic是Android中一项重要的网络设置&#xff0c;它控制了应用程序是否允许在不使用HTTPS加密的情况下访问网络。在默认情况下&#xff0c;usescleartexttraffic的值为true&#xff0c;这意味着应用程序可以通过普通的HTTP协议进行网络通信。然而&#xff0c;这…...

WebFlux vs WebMVC vs Servlet 对比

WebFlux vs WebMVC vs Servlet 技术对比 WebFlux、WebMVC 和 Servlet 是 Java Web 开发中三种不同的技术架构&#xff0c;它们在编程模型、并发模型和适用场景上有显著区别。以下是它们的核心对比&#xff1a; 核心区别总览 特性ServletSpring WebMVCSpring WebFlux编程模型…...

Spring MVC参数传递

本内容采用最新SpringBoot3框架版本,视频观看地址:B站视频播放 1. Postman基础 Postman是一个接口测试工具,Postman相当于一个客户端,可以模拟用户发起的各类HTTP请求,将请求数据发送至服务端,获取对应的响应结果。 2. Spring MVC相关注解 3. Spring MVC参数传递 Spri…...

Spring MVC 和 Spring Boot 是如何访问静态资源的?

Spring MVC 和 Spring Boot 在配置静态资源访问方面有所不同&#xff0c;Spring Boot 提供了更便捷的自动配置。 一、Spring Boot 如何配置静态资源访问 (推荐方式) Spring Boot 遵循“约定优于配置”的原则&#xff0c;对静态资源的访问提供了非常方便的自动配置。 默认静态…...

如何应对网站被爬虫和采集?综合防护策略与实用方案

在互联网时代&#xff0c;网站内容被恶意爬虫或采集工具窃取已成为常见问题。这不仅侵犯原创权益&#xff0c;还可能影响网站性能和SEO排名。以下是结合技术、策略与法律的综合解决方案&#xff0c;帮助网站构建有效防护体系。 一、技术防护&#xff1a;阻断爬虫的“技术防线”…...

MySQL 分页查询优化

目录 前言1. LIMIT offset, count 的性能陷阱&#xff1a;为什么它慢&#xff1f;&#x1f629;2. 优化策略一&#xff1a;基于排序字段的“跳跃式”查询 (Seek Method) &#x1f680;3. 优化策略二&#xff1a;利用子查询优化 OFFSET 扫描 (ID Subquery)4. 基础优化&#xff1…...

我用Deepseek + 亮数据爬虫神器 1小时做出輿情分析器

我用Deepseek 亮数据爬虫神器 1小时做出輿情分析器 一、前言二、Web Scraper API 实战&#xff08;1&#xff09;选择对应的URL&#xff08;2&#xff09;点击进入对应url界面&#xff08;3&#xff09;API结果实例和爬取结果展示&#xff08;4&#xff09;用户直接使用post请…...

langchain4j中使用milvus向量数据库做RAG增加索引

安装milvus向量数据库 官方网址 https://milvus.io/zh 使用docker安装milvus mkdir -p /data/docker/milvus cd /data/docker/milvus wget https://raw.githubusercontent.com/milvus-io/milvus/master/scripts/standalone_embed.sh#在docker中启动milvus sh standalone_emb…...

【开源工具】深度解析:基于PyQt6的Windows时间校时同步工具开发全攻略

&#x1f552; 【开源工具】深度解析&#xff1a;基于PyQt6的Windows时间校时同步工具开发全攻略 &#x1f308; 个人主页&#xff1a;创客白泽 - CSDN博客 &#x1f525; 系列专栏&#xff1a;&#x1f40d;《Python开源项目实战》 &#x1f4a1; 热爱不止于代码&#xff0c;热…...

开源 RPA 工具深度解析与官网指引

开源 RPA 工具深度解析与官网指引 摘要 &#xff1a;本文深入解析了多款开源 RPA 工具&#xff0c;涵盖 TagUI、Aibote、Taskt 等&#xff0c;分别介绍了它们的核心功能&#xff0c;并提供了各工具的官网链接&#xff0c;方便读者进一步了解与使用&#xff0c;同时给出了基于不…...

【免杀】C2免杀技术(一)VS设置

一、概述 编译器生成的二进制文件特征&#xff08;代码结构、元数据、指纹&#xff09;可能被杀软的静态或动态检测规则匹配。Visual Studio 的构建设置&#xff08;特别是运行库、编译器优化、链接方式等&#xff09;会直接影响最终生成的二进制文件的结构、行为特征和依赖关…...

OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——nettle库

准备工作 请依照这篇文章搭建环境 OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库——环境配置_openharmony交叉编译-CSDN博客 编译依赖 相关依赖有 gmp-6.3.0 请依照这篇文章编译 OpenHarmony 开源鸿蒙南向开发——linux下使用make交叉编译第三方库…...

Kotlin与Ktor构建Android后端API

以下是一个使用 Kotlin 和 Ktor 构建 Android 后端 API 的详细示例,包含常见功能实现: 1. 项目搭建 (build.gradle.kts) plugins {applicationkotlin("jvm") version "1.9.0"id("io.ktor.plugin") version "2.3.4"id("org.je…...

网页jupyter如何显示jpipvenv虚拟环境

今天使用社区版pycharm编辑.ipynb文件时&#xff0c;发现pycharm编辑.ipynb文件需要订阅。但是发现pipvenv虚拟环境解释器在jupyter中只有一个Python3:ipykernel版本&#xff0c;没有venv和conda的虚拟环境。因此在网上搜寻资料&#xff0c;作为备份记录。 以windows为例 假设目…...

学习黑客5 分钟深入浅出理解Windows System Configuration

5 分钟深入浅出理解Windows System Configuration ⚙️ 大家好&#xff01;今天我们将探索Windows系统配置——这是Windows操作系统的核心控制中心&#xff0c;决定了系统如何启动、运行和管理各种功能。无论你是计算机初学者&#xff0c;还是在TryHackMe等平台上学习网络安全…...

Spyglass:跨时钟域同步方案

相关阅读 Spyglasshttps://blog.csdn.net/weixin_45791458/category_12828934.html?spm1001.2014.3001.5482 Spyglass可以用于检测设计中的跨时钟域相关问题&#xff0c;确保电路中添加了适当的同步机制&#xff0c;以避免此类问题的发生&#xff0c;例如&#xff1a; 与亚稳…...

Ubuntu虚拟机文件系统扩容

1. 删除所有的虚拟机快照。 2. 选择扩展 将最大大小调整为你所需的大小 3. 进入虚拟机&#xff0c;输入命令&#xff1a; sudo apt install gparted sudo gparted 4. 选择磁盘&#xff0c;右键根分区&#xff0c;选择Resize/Move&#xff0c;调整大小。 5. 调整所需分区大…...

Window、CentOs、Ubuntu 安装 docker

Window 版本 网址&#xff1a;https://www.docker.com/ 下载 下载完成后&#xff0c;双击安装就可以了 Centos 版本 卸载 Docker &#xff08;可选&#xff09; yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-log…...

mac M2下虚拟机CentOS 8 安装上安装 Berkeley DB

问题&#xff1a;直接在centos8 yum安装db4-devel失败&#xff0c;只能手工安装 进入home目录&#xff0c;下载 wget http://download.oracle.com/berkeley-db/db-4.6.21.tar.gz 解压 tar -zxvf db-4.6.21.tar.gz 切到cd db-4.6.21的build_unix下 cd db-4.6.21 cd build_…...

Python文字转语音TTS库示例(edge-tts)

1. 安装 pip install edge-tts2. 命令行使用 # 生成语音文件 # -f&#xff1a;要转换语音的文本文件&#xff0c;例如一个txt文件 # --text&#xff1a;指明要保存的mp3的文本 # --write-media&#xff1a;指明保存的mp3文件路径 # --write-subtitles&#xff1a;指定输出字幕…...

lua入门语法,包含安装,注释,变量,循环等

文章目录 LUA入门什么是lualua安装入门lua的使用方式注释定义变量lua中的数据类型流程控制ifelsewhile语法&#xff1a;for 函数表模块 LUA入门 什么是lua 一种脚本语言&#xff0c;设计的目的是为了能够在一些应用程序提供灵活的扩展功能和定制功能。 lua安装 有linux版本…...

【文心智能体】使用文心一言来给智能体设计一段稳定调用工作流的提示词

&#x1f339;欢迎来到《小5讲堂》&#x1f339; &#x1f339;这是《文心智能体》系列文章&#xff0c;每篇文章将以博主理解的角度展开讲解。&#x1f339; &#x1f339;温馨提示&#xff1a;博主能力有限&#xff0c;理解水平有限&#xff0c;若有不对之处望指正&#xff0…...

TWASandGWAS中GBS filtering and GWAS(1)

F:\文章代码\TWASandGWAS\GBS filtering and GWAS README.TXT 请检查幻灯片“Vitamaize_update_Gorelab_Ames_GBS_filtering_20191122.pptx”中关于阿姆斯&#xff08;Ames&#xff09;ID处理流程的详细信息。 文件夹“Ames_ID_processing”包含了用于处理阿姆斯ID的文件和R…...

Linux电源管理(五),发热管理(thermal),温度控制

更多linux系统电源管理相关的内容请看&#xff1a;Linux电源管理、功耗管理 和 发热管理 (CPUFreq、CPUIdle、RPM、thermal、睡眠 和 唤醒)-CSDN博客 本文主要基于linux-5.4.18版本的内核代码进行分析。 1 简介 1.1 硬件知识 CPU等芯片在工作时会产生大量热量&#xff0c;…...

【C++11】异常

前言 上文我们学习到了C11中类的新功能【C11】类的新功能-CSDN博客 本文我们来学习C下一个新语法&#xff1a;异常 1.异常的概念 异常的处理机制允许程序在运行时就出现的问题进行相应的处理。异常可以使得我们将问题的发现和问题的解决分开&#xff0c;程序的一部分负…...