六:操作系统虚拟内存之缺页中断
深入理解操作系统:缺页中断 (Page Fault) 的处理流程
在上一篇文章中,我们介绍了虚拟内存和按需调页 (Demand Paging) 的概念。虚拟内存为每个进程提供了巨大的、独立的虚拟地址空间,并通过页表 (Page Table) 将虚拟页面 (Virtual Page) 映射到物理内存中的物理帧 (Physical Frame)。按需调页的核心在于:只有当程序试图访问一个尚未加载到物理内存中的页面时,操作系统才会将其从磁盘调入。
那么,当程序访问的页面不在内存中时,具体会发生什么?这就是我们今天要深入探讨的——缺页中断 (Page Fault)。
1. 什么是缺页中断?
缺页中断是一种特殊的中断 (Interrupt) 或更准确地说,是陷阱 (Trap) 或异常 (Exception)。它发生在当程序试图访问一个虚拟地址时,内存管理单元 (MMU) 在该进程的页表中查找对应的页表条目 (Page Table Entry, PTE),发现该页面的存在位 (Present Bit) 为 0。存在位为 0 表示该虚拟页面当前不在物理内存中。
此时,MMU 无法完成虚拟地址到物理地址的翻译,硬件会立即停止当前指令的执行,并产生一个内部中断信号,将控制权交给操作系统内核中预设的缺页中断处理程序 (Page Fault Handler)。
可以将其类比为:你去图书馆(物理内存)找一本图书(页面),但发现这本书(页面)不在架上(不在内存)。于是你向图书管理员(操作系统)求助,由图书管理员负责找到这本书(从磁盘调入)并带给你。
2. 缺页中断的处理流程
当缺页中断发生后,操作系统的缺页中断处理程序会接管控制权,执行一系列步骤来解决这个“页面不在内存”的问题,以便程序能够继续执行。这个过程是操作系统内存管理的核心部分之一。
以下是典型的缺页中断处理流程:
-
陷阱到操作系统内核 (Trap to the Operating System):
- 当 MMU 检测到访问的页面的存在位为 0 时,它会生成一个硬件中断(通常称为 Page Fault Exception)。
- 硬件将导致缺页的虚拟地址以及其他相关信息(如访问类型:读/写)压入进程的栈中,并切换 CPU 的执行模式到内核态。
- CPU 跳转到操作系统预设的缺页中断处理程序的入口地址。
-
保存进程状态 (Save Process State):
- 操作系统中断处理程序会保存当前正在执行的进程的上下文(寄存器、程序计数器等),以便稍后能够恢复其执行。
-
验证虚拟地址和权限 (Validate Virtual Address and Permissions):
- 操作系统首先检查导致缺页的虚拟地址是否合法。也就是说,这个地址是否属于当前进程的有效地址空间(例如,它是否在一个分配给进程的代码、数据或栈段内)。如果地址无效,说明这是一个非法内存访问(例如,访问了不属于自己的内存区域),这通常会导致一个段错误 (Segmentation Fault),操作系统会向该进程发送一个信号,通常会终止进程。
- 如果地址合法,操作系统还会检查进程对该页面的访问权限(例如,是试图写入只读页面吗?)。权限不匹配也会导致保护错误并可能终止进程。
- 如果地址合法且权限匹配,处理程序继续执行。
-
确定页面在磁盘上的位置 (Determine Page Location on Disk):
- 操作系统需要知道这个缺失的页面存储在磁盘的哪个位置。对于程序代码和静态数据,它通常位于程序的可执行文件中。对于堆 (heap) 或栈 (stack) 数据,它可能位于系统的交换空间 (Swap Space) 或分页文件 (Paging File)。操作系统会查找内部的数据结构(例如,页表的扩展信息或单独的结构)来确定磁盘地址。
-
查找空闲物理帧 (Find a Free Physical Frame):
- 操作系统需要在物理内存中找到一个空闲的物理帧,用于加载所需的页面。
- 操作系统维护着一个空闲物理帧列表。它会首先尝试从这个列表中获取一个空闲帧。
- 如果存在空闲帧: 直接分配一个空闲帧给该页面。
-
执行页面置换 (Page Replacement - If No Free Frame):
- 如果没有空闲物理帧: 这是内存紧张的情况。操作系统必须选择一个当前已经在物理内存中的页面作为“牺牲者”,将其从内存中移除,以便为新页面腾出空间。这个过程称为页面置换 (Page Replacement)。
- 操作系统会使用某种页面置换算法(如 LRU - Least Recently Used, FIFO - First-In First-Out, Clock 等)来选择要置换的页面。选择的目标通常是希望置换一个将来最不可能被访问的页面。
- 处理“脏页” (Handle “Dirty” Pages): 在置换页面之前,操作系统会检查被选中的“牺牲者”页面的页表条目中的修改位/脏位 (Dirty Bit)。如果脏位为 1,表示该页面在加载到内存后被修改过,其内容与磁盘上的原始副本不一致。为了保存这些修改,操作系统必须将该页面写回磁盘(通常是写回交换空间)后再释放其物理帧。这是一个额外的、开销较大的 I/O 操作。
- 如果脏位为 0,表示页面未被修改,可以直接丢弃内存中的副本,因为磁盘上的副本是最新的。
- 更新被置换页面的页表条目:将被置换页面的存在位设置为 0,清除其物理帧号信息。
-
将所需页面从磁盘读入物理内存 (Read Required Page from Disk to Frame):
- 操作系统发起一个磁盘 I/O 请求,将第 4 步中确定的页面从磁盘位置读取到第 5 或 6 步中找到的物理帧中。这是一个耗时较长的操作(相对于 CPU 指令执行速度)。在等待磁盘 I/O 完成期间,操作系统通常会将 CPU 分配给其他处于就绪状态的进程执行。
-
更新页表 (Update Page Table):
- 磁盘 I/O 完成后,所需页面已成功加载到物理内存的某个物理帧中。
- 操作系统更新当前进程的页表,找到导致缺页的虚拟页面对应的页表条目。
- 将该条目的存在位设置为 1。
- 将该条目的物理帧号更新为页面实际加载到的物理帧号。
- 根据程序的访问类型,设置页面的访问权限位(读、写、执行)。
- 将脏位和访问位清零(初始状态)。
-
恢复进程执行 (Restart or Continue Process Execution):
- 操作系统恢复之前保存的进程状态。
- 最关键的一步是:操作系统会修改程序计数器,使其指向导致缺页中断的那条指令的开头。
- 进程在用户态下恢复执行。当 CPU 再次尝试执行那条指令时,MMU 会再次进行地址翻译。这一次,由于操作系统已经将所需的页面加载到内存并更新了页表,MMU 查找页表时会发现存在位为 1,能够成功翻译虚拟地址为物理地址,指令得以正常完成。
3. 缺页中断处理的例子
假设一个程序试图访问数组 arr[i]
。在编译后的机器码中,这可能对应于一条加载(Load)或存储(Store)指令,其操作数使用虚拟地址 &arr + i * sizeof(element)
。
- CPU 执行指令,计算出要访问的虚拟地址
VA
。 - CPU 将
VA
发送给 MMU 进行翻译。 - MMU 查找当前进程的页表,发现
VA
所属的虚拟页面的页表条目中,存在位是 0。 - MMU 触发一个缺页中断。
- CPU 切换到内核态,跳转到操作系统的缺页中断处理程序。
- 操作系统:
- 保存当前进程的上下文。
- 检查
VA
是否合法地址,以及访问权限(是读还是写,进程是否有权限)。假设合法。 - 确定
VA
所在的虚拟页面对应于arr
数组的某个部分,这个页面在磁盘上的某个位置(比如在程序的原始数据段或交换空间)。 - 查找物理内存中的空闲帧。假设没有空闲帧,需要进行页面置换。
- 选择一个页面
P_victim
进行置换(例如,使用了 LRU 算法选了一个很久没用的页面)。 - 检查
P_victim
的脏位。假设P_victim
的脏位是 1(它被修改过)。操作系统发起一个 I/O 操作,将P_victim
的内容写回磁盘的交换空间。 - 操作系统更新
P_victim
对应的页表条目,将其存在位设为 0。 P_victim
占用的物理帧现在变为空闲。操作系统发起第二个 I/O 操作,将导致缺页的那个页面(包含arr[i]
)从磁盘读入这个刚刚释放的物理帧。- I/O 操作完成。操作系统更新
VA
所在页面的页表条目,设置存在位为 1,记录新的物理帧号。 - 操作系统恢复进程上下文,并将程序计数器设置回导致缺页中断的那条 Load/Store 指令的开头。
- 进程在用户态下恢复执行。CPU 再次执行 Load/Store 指令,尝试访问
VA
。 - MMU 再次翻译
VA
。这一次,页表中对应的存在位是 1,MMU 成功翻译出物理地址。 - CPU 使用物理地址访问内存,Load/Store 指令成功完成。程序继续正常执行。
整个过程从程序执行的角度来看,除了由于磁盘 I/O 导致的延迟之外,是透明的。程序并不知道它刚刚经历了一次缺页中断和页面加载。
4. 缺页中断的开销
缺页中断处理是一个复杂的、涉及硬件和软件协作的过程,其中最耗时的部分是磁盘 I/O 操作。与 CPU 执行一条指令(纳秒级别)相比,磁盘访问需要数毫秒甚至更长时间,这是几个数量级的差异。
频繁的缺页中断(称为颠簸 (Thrashing))会导致系统大部分时间都在忙于页面调入调出,而用户进程实际执行指令的时间很少,系统性能急剧下降。这是物理内存不足以支持当前进程的工作集(Work Set,即进程在一段时间内频繁访问的页面集合)时常发生的情况。
然而,在大多数正常情况下,由于程序的局部性原理 (Principle of Locality)(包括时间局部性和空间局部性),程序在一段时间内只会访问其工作集中的页面。按需调页能够有效地利用物理内存,只加载这些活跃页面,从而在有限的物理内存下支持更多或更大的程序运行。缺页中断虽然有开销,但其带来的内存利用率和多道程序度(Multiprogramming Degree)的提升通常是值得的。
总结
缺页中断是虚拟内存和按需调页机制中不可避免的一部分。它是一个由 MMU 触发的硬件异常,通知操作系统某个被访问的虚拟页面不在物理内存中。操作系统的缺页中断处理程序负责定位缺失页面、寻找物理内存空间(可能需要置换其他页面)、将页面从磁盘加载到内存,并更新页表,最终让导致缺页的指令重新执行成功。
理解缺页中断的处理流程,对于理解虚拟内存的工作原理、内存性能瓶颈以及操作系统的复杂性至关重要。它是现代操作系统能够高效管理内存、运行大型程序和支持多任务的关键技术之一。
相关文章:
六:操作系统虚拟内存之缺页中断
深入理解操作系统:缺页中断 (Page Fault) 的处理流程 在上一篇文章中,我们介绍了虚拟内存和按需调页 (Demand Paging) 的概念。虚拟内存为每个进程提供了巨大的、独立的虚拟地址空间,并通过页表 (Page Table) 将虚拟页面 (Virtual Page) 映射…...
iOS 15.4.1 TrollStore(巨魔商店)安装教程详解:第二篇
🚀 iOS 15.4.1 TrollStore(巨魔商店)安装教程详解 ✨ 前言🛠️ 如何安装 TrollStore?第一步:打开 Safari 浏览器第二步:选择对应系统版本安装方式第三步:访问地址,下载配…...
【JAVA】比较器Comparator与自然排序(28)
JAVA 核心知识点详细解释 Java中比较器Comparator的概念和使用方法 概念 Comparator 是 Java 中的一个函数式接口,位于 java.util 包下。它用于定义对象之间的比较规则,允许我们根据自定义的逻辑对对象进行排序。与对象的自然排序(实现 Comparable 接口)不同,Comparat…...
bitbar环境搭建(ruby 2.4 + rails 5.0.2)
此博客为武汉大学WA学院网络安全课程,理论课大作业Web环境搭建。 博主搭了2天!!!血泪教训是还是不能太相信ppt上的教程。 一开始尝试了ppt上的教程,然后又转而寻找网络资源 cs155源代码和docker配置,做到…...
Spring Boot接口通用返回值设计与实现最佳实践
一、核心返回值模型设计(增强版) package com.chat.common;import com.chat.util.I18nUtil; import com.chat.util.TraceUtil; import lombok.AllArgsConstructor; import lombok.Data; import lombok.Getter;import java.io.Serializable;/*** 功能: 通…...
线上 Linux 环境 MySQL 磁盘 IO 高负载深度排查与性能优化实战
目录 一、线上告警 二、问题诊断 1. 系统层面排查 2. 数据库层面分析 三、参数调优 1. sync_binlog 参数优化 2. innodb_flush_log_at_trx_commit 参数调整 四、其他优化建议 1. 日志文件位置调整 2. 生产环境核心参数配置模板 3. 突发 IO 高负载应急响应方案 五、…...
React--函数组件和类组件
React 中的函数组件和类组件是两种定义组件的方式,它们有以下主要区别: 1. 语法与定义方式 函数组件: 是 JavaScript 函数,接收 props 作为参数,返回 JSX。 const MyComponent (props) > {return <div>Hell…...
GitHub 趋势日报 (2025年05月20日)
本日报由 TrendForge 系统生成 https://trendforge.devlive.org/ 🌐 本日报中的项目描述已自动翻译为中文 📈 今日整体趋势 Top 10 排名项目名称项目描述今日获星总星数语言1virattt/ai-hedge-fundAI对冲基金团队⭐ 1781⭐ 31163Python2public-apis/pub…...
uni.getLocation()和uni.openSetting()
文章目录 环境背景问题分析问题1问题2 uni.getLocation()和uni.openSetting()的区别和联系其它uni.getLocation()的failuni.openSetting()的authSetting对象 参考 环境 Windows 11 专业版HBuilder X 4.65微信开发者工具 Stable 1.06.2412050 背景 在小程序开发中,…...
医疗行业数据共享新实践:如何用QuickAPI打通诊疗全流程数据壁垒
在医疗行业,数据的高效流转直接影响诊疗效率和患者体验。某三甲医院在数字化转型中发现,虽然已积累大量核心业务数据,但各科室系统间的数据互通仍存在明显瓶颈——检验科的报告无法实时同步至门诊系统,药房库存数据与采购系统脱节…...
管理会议最佳实践:高效协同与价值最大化
1.会前准备:明确目标与计划 1.1 明确会议目的 1.1.1 必要性评估 开会前需自问是否真的需要开会,若问题可通过邮件、文档或异步沟通解决,则应避免开会,以节省时间和资源。 1.1.2 目标定义 清晰定义会议目标,如决策、信息同步、创意讨论等,并提前告知参与者,使大家明确参…...
万物智联,重塑未来:鸿蒙操作系统的实战突破与生态崛起
鸿蒙操作系统(HarmonyOS)作为华为自主研发的分布式操作系统,自2019年发布以来,已从技术探索迈入大规模商用阶段。截至2025年,鸿蒙系统不仅成为全球第二大移动操作系统,更在政企数字化、工业制造、金融科技等…...
人工智能路径:技术演进下的职业发展导航
当生成式AI能够自主完成创意设计、商业分析和代码编写时,职业发展的传统路径正在被重新测绘。人工智能路径不再是一条预设的直线,而演变为包含多重可能性的动态网络——未来的职业成功,将取决于在技术变革中持续定位自身价值节点的能力。 一…...
深入理解Java虚拟机之垃圾收集器篇(垃圾回收器的深入解析待完成TODO)
目录 **一. 如何判断对象的存亡**引用计数算法:可达性分析算法: **二. Java中的四种引用****三. 垃圾回收算法****1. 标记 - 清除算法****2. 标记 - 复制算法****3. 标记 - 整理算法****4. 分代收集理论**(了解即可) **四. 十种主流垃圾收集器****3.1 Serial 收集器****3.2 Par…...
牛客网 NC16407 题解:托米航空公司的座位安排问题
牛客网 NC16407 题解:托米航空公司的座位安排问题 题目分析 解题思路 本题可以采用深度优先搜索(DFS)来解决: 从左上角开始,按行优先顺序遍历每个座位对于每个座位,有两种选择: 选择该座位(如果满足条件…...
拉普拉斯高斯(LoG)滤波器掩模的注意事项
目录 问题: 解答: 一、高斯函数归一化:消除幅度偏差 1. 归一化的定义 2. 为何必须归一化? 二、拉普拉斯系数和为零:抑制直流项干扰 1. 拉普拉斯算子的特性 2. 系数和不为零的后果 三、直流项如何影响零交叉点&…...
OSPF基础实验-多区域
互联接口、IP地址如下图所示,所有设备均创建Loopback0,其IP地址为10.0.x.x/24,其中x为设备编号。 R1、R3的所有接口以及R2的GE0/0/4接口属于OSPF区域2,R2、R4的Loopback0接口及互联接口属于OSPF区域0,R4、R5的互联接口…...
ERP 与 WMS 对接深度解析:双视角下的业务与技术协同
在企业数字化运营的复杂体系中,ERP(企业资源规划)与 WMS(仓储管理系统)的有效对接,已成为优化供应链管理、提升运营效率的关键环节。本文将从 ERP 和 WMS 两个核心视角出发,深度剖析两者对接过程…...
基于 Node.js 的 HTML 转 PDF 服务
这是一个基于 Node.js 开发的 Web 服务,主要功能是将 HTML 内容转换为 PDF 文件。项目使用了 Express 作为 Web 框架,Puppeteer 作为 PDF 生成引擎,提供了简单易用的 API 接口。前端开发人员提供了一个简单而强大的 HTML 转 PDF 解决方案&…...
Java阻塞队列(BlockingQueue)的使用:ArrayBlockingQueue类、LinkedBlockingQueue类
1、阻塞队列的介绍 Java 中的阻塞队列(BlockingQueue) 是多线程编程中用于协调生产者和消费者线程的重要工具,属于 java.util.concurrent 包。它的核心特点是:当队列为空时,消费者线程会被阻塞,直到队列中有新元素;当队列满时,生产者线程会被阻塞,直到队列有空闲…...
esp32cmini SK6812 2个方式
1 #include <SPI.h> // ESP32-C系列的SPI引脚 #define MOSI_PIN 7 // ESP32-C3/C6的SPI MOSI引脚 #define NUM_LEDS 30 // LED灯带实际LED数量 - 确保与实际数量匹配! #define SPI_CLOCK 10000000 // SPI时钟频率 // 颜色结构体 st…...
2025年 PMP 6月 8月 专题知识
2025年 PMP 6月 8月 专题知识 文章目录 2025年 PMP 6月 8月 专题知识三点估算1. 概念:2. 原理: 决策树1. 概念:2. 步骤: 真题 三点估算 1. 概念: 三点估算常用于估算活动持续时间(也可以用于估算成本);源自计划评审技术(PERT&am…...
一文理解TCP与UDP
Socket套接字 Socket套接字,是由系统提供用于网络通信的技术,是基于TCP/IP协议的网络通信的基本操作单元。 基于Socket套接字的网络程序开发就是网络编程。 Socket套接字主要针对传输层协议划分为如下三类: 流套接字:使用传输层…...
智能指针RAII
引入:智能指针的意义是什么? RAll是一种利用对象生命周期来控制程序资源(如内存、文件句柄、网络连接、互斥量等等)的简单技术。 在对象构造时获取资源,接着控制对资源的访问使之在对象的生命周期内始终保持有效&#…...
AI护航化工:《山西省危化品视频智能分析指南》下的视频分析重构安全体系
化工和危化品行业的AI智能视频分析应用:构建安全与效率新范式 一、行业背景与挑战 化工和危化品行业是国民经济的重要支柱,但生产过程涉及高温、高压、易燃易爆等高风险场景。传统安全监管依赖人工巡检和固定监控设备,存在效率低、盲区多、…...
GitHub SSH Key 配置详细教程(适合初学者,Windows版)-学习记录4
GitHub SSH Key 配置详细教程(适合初学者,Windows版) 本教程适用于在 Windows 系统下,将本地 Git 仓库通过 SSH 方式推送到 GitHub,适合没有配置过 SSH key 的初学者。 1. 检查是否已有 SSH key 打开 Git Bash 或 Po…...
初识Linux · NAT 内网穿透 内网打洞 代理
目录 前言: 内网穿透和打洞 NAPT表 内网穿透 内网打洞 正向/反向代理 前言: 本文算是网络原理的最后一点补充,为什么说是补充呢,因为我们在前面第一次介绍NAT的时候详细介绍的是报文从子网到公网,却没有介绍报文…...
docker-compose使用详解
Docker-Compose 是 Docker 官方提供的容器编排工具,用于简化多容器应用的定义、部署和管理。其核心功能是通过 YAML 配置文件(docker-compose.yml)定义服务、网络和存储卷,并通过单一命令实现全生命周期的管理。以下从核心原理、安…...
使用计算机视觉实现目标分类和计数!!超详细入门教程
什么是物体计数和分类 在当今自动化和技术进步的时代,计算机视觉作为一项关键工具脱颖而出,在物体计数和分类任务中提供了卓越的功能。 无论是在制造、仓储、零售,还是在交通监控等日常应用中,计算机视觉系统都彻底改变了我们感知…...
并发编程中的对象组合的哲学
文章目录 引言对象组合与安全委托实例封闭技术基于监视器模式的对象访问对象不可变性简化委托原子维度的访问现有容器的并发安全的封装哲学使用继承使用组合小结参考引言 本文将介绍通过封装技术,保证开发者不对整个程序进行分析的情况下,就可以明确一个类是否是线程安全的,…...
03-Web后端基础(Maven基础)
1. 初始Maven 1.1 介绍 Maven 是一款用于管理和构建Java项目的工具,是Apache旗下的一个开源项目 。 Apache 软件基金会,成立于1999年7月,是目前世界上最大的最受欢迎的开源软件基金会,也是一个专门为支持开源项目而生的非盈利性…...
禁忌搜索算法:从原理到实战的全解析
禁忌搜索算法:从原理到实战的全解析 一、算法起源与核心思想 禁忌搜索(Tabu Search, TS)由美国工程院院士Fred Glover于1986年正式提出,其灵感源于人类的记忆机制——通过记录近期的搜索历史(禁忌表)&…...
从加密到信任|密码重塑车路云一体化安全生态
目录 一、密码技术的核心支撑 二、典型应用案例 三、未来发展方向 总结 车路云系统涉及海量实时数据交互,包括车辆位置、传感器信息、用户身份等敏感数据。其安全风险呈现三大特征: 开放环境威胁:V2X(车与万物互联࿰…...
【ffmpeg】SPS与PPS的概念
PPS(Picture Parameter Set)详解 PPS(图像参数集)是H.264/H.265视频编码标准中的关键数据结构,与SPS(序列参数集)共同组成视频的解码配置信息,直接影响视频的正确解码和播放。以下是…...
Java垃圾回收与JIT编译优化
1. Java中的垃圾回收 垃圾回收是Java内存管理的核心,负责自动回收不再被应用程序引用的对象内存,从而防止内存泄漏并优化资源使用。以下详细介绍垃圾回收的机制、算法及优化实践。 1.1 垃圾回收的必要性 垃圾回收解决了手动内存管理中的常见问题,如内存泄漏和悬空指针。它…...
mmaction2——tools文件夹下
build_rawframes.py 用法示例 python tools/data/build_rawframes.py data/videos data/frames --task rgb --level 2 --ext mp4 --use-opencv --num-worker 8总结: 只需要 RGB 帧,推荐 --use-opencv,简单高效,无需额外依赖。 …...
论文阅读:Next-Generation Database Interfaces:A Survey of LLM-based Text-to-SQL
地址:Next-Generation Database Interfaces: A Survey of LLM-based Text-to-SQL 摘要 由于用户问题理解、数据库模式解析和 SQL 生成的复杂性,从用户自然语言问题生成准确 SQL(Text-to-SQL)仍是一项长期挑战。传统的 Text-to-SQ…...
Devicenet主转Profinet网关助力改造焊接机器人系统智能升级
某汽车零部件焊接车间原有6台焊接机器人(采用Devicenet协议)需与新增的西门子S7-1200 PLC(Profinet协议)组网。若更换所有机器人控制器或上位机系统,成本过高且停产周期长。 《解决方案》 工程师选择稳联技术转换网关…...
【HTML-5】HTML 实体:完整指南与最佳实践
1. 什么是 HTML 实体? HTML 实体是一种在 HTML 文档中表示特殊字符的方法,这些字符如果直接使用可能会与 HTML 标记混淆,或者无法通过键盘直接输入。实体由 & 符号开始,以 ; 分号结束。 <p>这是一个小于符号的实体&am…...
MySQL 索引详解与原理分析
MySQL 索引详解与原理分析 一、什么是索引? 索引(Index)是数据库表中一列或多列的值进行排序的一种数据结构,可以加快数据的检索速度。索引类似于书本的目录,通过目录可以快速定位到想要的内容,而不用全书…...
游戏引擎学习第303天:尝试分开对Y轴和Z轴进行排序
成为我们自己的代码精灵α 所以现在应该可以正常使用了。不过,这两周我们没办法继续处理代码里的问题,而之前留在代码里的那个问题依然存在,没有人神奇地帮我们修复,这让人挺无奈的。其实我们都希望有个神奇的“代码仙子”&#…...
javaweb-html
1.交互流程: 浏览器向服务器发送http请求,服务器对浏览器进行回应,并发送字符串,浏览器能对这些字符串(html代码)进行解释; 三大web语言:(1)html:…...
3.2.3
# 导入必要的库 import onnx import numpy as np from PIL import Image import onnxruntime as ort # 定义预处理函数,用于将图片转换为模型所需的输入格式 def preprocess(image_path): input_shape (1, 1, 64, 64) # 模型输入期望的形状,这里…...
Redis 8.0 GA,重回开源
在数字化浪潮的推动下,实时数据处理已成为现代应用的核心需求。作为全球广泛使用的 NoSQL 数据库,Redis 8.0 不仅通过 30 余项性能改进重新定义了实时数据处理的速度极限,更通过整合社区资源与开放授权模式,进一步巩固其在开源生态…...
心联网(社群经济)视角下开源AI智能名片、链动2+1模式与S2B2C商城小程序源码的协同创新研究
摘要:在心联网(社群经济)理论框架下,本文构建了开源AI智能名片、链动21模式与S2B2C商城小程序源码的技术协同体系,提出"情感连接-利益驱动-生态裂变"三维创新模型。通过实证分析与案例研究,验证该…...
【图像大模型】Hunyuan-DiT:腾讯多模态扩散Transformer的架构创新与工程实践
Hunyuan-DiT:腾讯多模态扩散Transformer的架构创新与工程实践 一、架构设计与技术创新1.1 核心架构解析1.2 关键技术突破1.2.1 多粒度训练策略1.2.2 动态路由MoE 二、系统架构解析2.1 完整生成流程2.2 性能对比 三、实战部署指南3.1 环境配置3.2 基础推理代码3.3 高…...
TASK04【Datawhale 组队学习】构建RAG应用
目录 将LLM接入LangChain构建检索问答链运行成功图遇到的问题 langchain可以便捷地调用大模型,并将其结合在以langchain为基础框架搭建的个人应用中。 将LLM接入LangChain from langchain_openai import ChatOpenAI实例化一个 ChatOpenAI 类,实例化时传入超参数来…...
YOLOv11旋转目标检测Hrsc2016
from ultralytics import YOLOmodel YOLO(/kaggle/input/model-v11-obb/yolo11n-obb.pt) model.train(data/kaggle/input/hrscobb4/HRSC-YOLO/data.yaml, epochs30) 1使用的训练平台为Kaggle 数据集:HRSC的三种形式 一级分类:船 有水平框版本&…...
Debian重装系统后
安装配置java环境 手动安装 下载openJDK:openJDK 设置替代项 sudo update-alternatives --install /usr/bin/java java /opt/jdk-21.0.2/bin/java 1 sudo update-alternatives --install /usr/bin/javac javac /opt/jdk-21.0.2/bin/javac 1 sudo update-alternat…...
野火鲁班猫(arrch64架构debian)从零实现用MobileFaceNet算法进行实时人脸识别(四)安装RKNN Toolkit Lite2
RKNN Toolkit Lite2 是瑞芯微专为RK系列芯片开发的NPU加速推理API。若不使用该工具,计算任务将仅依赖CPU处理,无法充分发挥芯片高达6TOPS的NPU算力优势。 按照官方文档先拉一下官方代码库,然后通过whl文件安装,因为我是python3.1…...