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

操作系统 4.2-键盘

键盘中断初始化和处理

提取的代码如下:

// con_init 函数,初始化控制台(包括键盘)的中断
void con_init(void) {set_trap_gate(0x21, &keyboard_interrupt);
}
​
// 键盘中断处理函数
.globl _keyboard_interrupt
_keyboard_interrupt:inb $0x60, %al // 从端口0x60读扫描码call key_table(%eax, 4) // 调用key_table+eax*4push $0call _do_tty_interrupt

总结:

这段代码描述了键盘中断初始化和处理的过程:

  1. 键盘中断初始化 (con_init 函数):

    • con_init 函数设置键盘中断门(trap gate),将键盘中断处理函数 keyboard_interrupt 地址加载到中断向量 0x21

    • 这个函数是控制台(包括键盘)初始化的一部分,确保键盘输入能够触发中断。

  2. 键盘中断处理 (_keyboard_interrupt 函数):

    • 当键盘被敲击时,产生中断信号。

    • 中断处理函数 _keyboard_interrupt 被调用,从端口 0x60 读取键盘扫描码。

    • 调用 key_table 函数处理扫描码,key_table 是一个查找表,用于将扫描码转换为字符。

    • 0 压栈,然后调用 _do_tty_interrupt 函数进一步处理字符输出。

当用户敲击键盘时,触发中断,操作系统捕获中断并调用相应的中断处理函数来读取和处理键盘输入。这是实现键盘输入功能的关键步骤。

处理键盘输入的扫描码

提取的代码如下:

// 在 kernel/chr_drv/keyboard.s 中定义的 key_table
key_table:.long none, do_self, do_self, do_self // 扫描码00-03.long do_self, ..., func, scroll, cursor 等等
​
// do_self 函数
do_self:lea alt_map, %ebxtestb $0x20, mode // alt键是否同时按下jne 1flea shift_map, %ebxtestb $0x03, modejne 1flea key_map, %ebx
1:

总结:

这段代码展示了 Linux 内核如何处理键盘输入的扫描码,并将它们转换为字符输出。具体来说:

  1. 定义 key_table 函数数组

    • key_table 是一个函数数组,用于处理不同的键盘扫描码。每个条目对应一个扫描码的处理函数。

  2. 处理扫描码

    • 扫描码 02 对应按键 101 对应 ESC12 对应 E 等。

  3. 处理函数 do_self

    • do_self 函数用于处理特定的扫描码。

    • 它首先加载 alt_mapebx 寄存器。

    • 检查 mode 寄存器,确定 alt 键是否被按下。

    • 如果 alt 键被按下,它加载 shift_mapebx 寄存器。

    • 否则,它加载 key_mapebx 寄存器。

    • key_mapshift_mapalt_map 是映射表,用于将扫描码转换为相应的字符。

  4. 映射表

    • 映射表(如 key_map)用于将扫描码转换为字符。例如,akey_map 映射为 a,而 shift_map 映射为 A

这个过程展示了如何通过映射表和条件逻辑将键盘扫描码转换为字符,并将它们输出到屏幕上。这是键盘输入处理的核心部分,它确保了用户输入能够被正确识别和显示。

key_map 中取出对应的 ASCII 码

提取的代码如下:

#if defined(KBD_US)
key_map: .byte 0,27 .ascii "1234567890-="
shift_map: .byte 0,27 .ascii "!@#$%^&*()_+"
#elif defined(KBD_GR)...
#endif
​
# 继续do_self,从1f开始,ebx放的是map起始地址
1: movb (%ebx, %eax), %al // 扫描码索引,ASCII码->alorb %al, %al     je none  // 没有对应的ASCII码testb $0x4c, mode  // 看caps是否亮je 2f  cmpb $'a, %al  jb 2fcmpb $'}, %al   ja 2f  subb $32, %al // 变大写
2: testb $??, mode  // 处理其他模式,如ctrl同时按下
3: andl $0xff, %eax call put_queue
none: ret

总结:

这段代码展示了如何从 key_map 中取出对应的 ASCII 码,并根据键盘的模式(如大写锁定 Caps LockShift 键)进行相应的处理。以下是详细步骤:

  1. 定义键盘映射表

    • key_mapshift_map 是两个映射表,分别用于处理未按下 Shift 键和按下 Shift 键时的键盘输入。

    • 这些映射表将键盘扫描码转换为 ASCII 码。

  2. key_map 中取出 ASCII 码

    • 根据扫描码索引从 key_map 中取出对应的 ASCII 码。

    • 如果没有找到对应的 ASCII 码,则跳转到 none 标签。

  3. 处理大写锁定

    • 检查 Caps Lock 模式是否激活(testb $0x4c, mode)。

    • 如果激活,将小写字母转换为大写字母(cmpb $'a, %alsubb $32, %al)。

  4. 处理其他模式

    • 检查是否有其他模式激活,如 Ctrl 键同时按下(testb $??, mode)。

    • 根据需要处理这些模式。

  5. 将字符放入队列

    • 将处理后的 ASCII 码放入输出队列(put_queue)。

  6. 返回

    • 如果没有找到对应的 ASCII 码,则返回(none: ret)。

处理键盘输入并将字符放入队列中

提取的代码如下:

// put_queue 函数
put_queue:movl _table_list, %edxmovl head(%edx), %ecx
1:movb %al, buf(%edx, %ecx)...
// do_tty_interrupt 函数
void do_tty_interrupt(int tty) {copy_to_cooked(tty_table + tty);
}
​
// copy_to_cooked 函数
void copy_to_cooked(struct tty_struct *tty) {GETCH(tty->read_q, c);if (L_ECHO(tty)) { // 回显,也可以不回显PUTCH(c, tty->write_q);tty->write(tty); } // 立刻显示到屏幕上PUTCH(c, tty->secondary); // 完成copy_to_cooked... wake_up(&tty->secondary.proc_list);
}

总结:

这段代码描述了 Linux 内核如何处理键盘输入并将字符放入队列中的过程:

  1. put_queue 函数

    • 该函数负责将字符放入 con.read_q 队列中。

    • 它首先将 _table_list 地址加载到 edx 寄存器,然后获取 head 指针到 ecx 寄存器。

    • 接着,它从缓冲区 buf 中取出字符并放入队列中。

  2. do_tty_interrupt 函数

    • 该函数处理键盘中断,调用 copy_to_cooked 函数来处理键盘输入。

  3. copy_to_cooked 函数

    • 该函数从 tty->read_q 队列中获取字符。

    • 如果 L_ECHO 标志被设置(表示回显),则将字符放入 tty->write_q 队列中。

    • 然后调用 tty->write(tty) 函数将字符立刻显示到屏幕上。

    • 将字符放入 tty->secondary 队列中,完成 copy_to_cooked 操作。

    • 最后,唤醒等待在 tty->secondary.proc_list 队列中的进程。

这个过程展示了如何将键盘输入的字符处理并放入队列中,以便后续显示在屏幕上

键盘处理的步骤总结

  1. 中断初始化

    • 键盘作为控制台(console)的一部分,其中断通过 con_init 函数进行初始化,设置中断门(trap gate)以响应键盘事件。

  2. 中断处理

    • 当用户敲击键盘时,产生中断信号,操作系统通过中断处理程序 keyboard_interrupt 来响应这个中断。

    • 中断处理程序从键盘的端口(通常是 0x60)读取扫描码。

  3. 扫描码转换

    • 根据读取到的扫描码,调用 key_table 函数数组来查找对应的处理函数或映射表。

    • 扫描码对应键盘上的不同按键,如 02 对应数字键 101 对应 ESC 键等。

  4. 字符映射

    • 对于显示字符,使用 key_map 映射表将扫描码转换为 ASCII 码。

    • 如果按下 ShiftAlt 等修饰键,可能会使用 shift_mapalt_map 来获取大写字母或特殊字符。

  5. 队列处理

    • 将转换得到的 ASCII 码放入 write_q 队列中,等待显示设备(如显示器)来读取并显示。

    • 如果设置了回显(L_ECHO),则同时将字符放入 read_q 队列中,以便用户可以看到自己输入了什么。

  6. 显示字符

    • con_write 函数负责从 write_q 队列中取出字符并通过显示器驱动程序 tty_write 输出到屏幕上。

  7. 缓冲和回显

    • copy_to_cooked 函数处理 read_q 队列中的字符,可能包括回显逻辑,即将字符回显到屏幕上。

到显示器和键盘的交互

这张图展示了Linux内核中字符设备(特别是TTY设备)的读写流程。以下是流程的总结:

写流程(从上到下):

  1. 系统调用 (write) :应用程序通过系统调用 write 向内核请求写操作。

  2. 字符设备接口 (crw_table[]) :系统调用被路由到字符设备接口,具体到 char_dev.c 文件中的相关函数。

  3. TTY设备写 (tty_write) :字符设备接口调用 tty_write 函数,该函数位于 tty_io.c 文件中。

  4. write_q队列:写操作的数据被放入 write_q 队列中。

  5. 显示器写 (con_write) :数据从 write_q 队列被取出并通过 con_write 函数写入显示器,该函数位于 console.c 文件中。

  6. 显示器:最终数据被显示在显示器上。

读流程(从下到上):

  1. 主机键盘:用户通过键盘输入数据。

  2. keyboard.S:键盘输入的数据被处理并放入 read_q 队列中。

  3. read_q队列:键盘输入的数据存储在 read_q 队列中。

  4. TTY设备读 (tty_read) :应用程序通过系统调用 read 请求读操作,该请求被路由到 tty_read 函数,该函数位于 tty_io.c 文件中。

  5. 字符设备接口 (crw_table[])tty_read 函数通过字符设备接口返回数据给应用程序。

  6. 系统调用 (read) :最终数据被返回给应用程序。

回显流程:

  1. 回显:键盘输入的数据不仅被放入 read_q 队列,还会被回显到 write_q 队列中。

  2. 显示器写 (con_write) :回显的数据通过 con_write 函数写入显示器,显示用户输入的内容。

总结:

  • 写操作:从应用程序的 write 系统调用开始,经过字符设备接口、TTY设备写、写队列,最终写入显示器。

  • 读操作:从键盘输入开始,经过键盘处理、读队列、TTY设备读、字符设备接口,最终返回给应用程序的 read 系统调用。

  • 回显:键盘输入的数据会被同时写入读队列和写队列,实现输入内容的即时显示。

这个流程展示了Linux内核中字符设备(特别是TTY设备)的读写机制,确保了数据的正确传输和显示。

相关文章:

操作系统 4.2-键盘

键盘中断初始化和处理 提取的代码如下: // con_init 函数,初始化控制台(包括键盘)的中断 void con_init(void) {set_trap_gate(0x21, &keyboard_interrupt); } ​ // 键盘中断处理函数 .globl _keyboard_interrupt _keyboard…...

24.0.2 双系统ubuntu 安装显卡驱动黑屏,系统启动界面键盘失灵

问题描述:通过run文件在ubuntu 界面版安装nvidia 驱动后,忽然黑屏,再次启动时,键盘鼠标失灵无法选择系统,只能进入ubuntu界面。第二个问题是ubuntu 也无法用户登录,左上角光标闪烁。 查询方案,…...

探索多领域免费API资源库:打造数据查询利器

在当今信息爆炸的时代,获取各种领域的数据已成为许多人的需求。而免费API资源库的出现为我们提供了便捷的途径,让我们可以轻松地获取所需数据。本文将介绍涵盖20领域的免费API资源库,通过代码示例展示其功能,帮助读者更好地理解和…...

jenkins项目发布-安装k8s(rancher)客户端kubectl

找一台Linux 上安装 kubectl 以下是通过国内镜像源快速安装 kubectl 的方法,适合国内网络环境。 1. 下载 kubectl 通过国内镜像源下载指定版本的 kubectl: 使用阿里云镜像源下载: curl -LO "https://dl.k8s.io/release/$(curl -L -…...

【2025年认证杯数学中国数学建模网络挑战赛】C题 数据预处理与问题一二求解

目录 2025认证杯网络挑战赛A题 数据预处理与问题一求解三、数据预处理及分析3.1 数据可视化3.2 滑动窗口相关系数统计与动态置信区间耦合分析模型3.3 耦合关系分析结果 四、问题一代码数据预处理问题一 2025认证杯网络挑战赛 A题 数据预处理与问题一求解 三、数据预处理及分析…...

天玑AI开发套件2.0模型库数量激增3.3倍,让AI开发选择更自由

AI终端能力的升级,从不止步于硬件性能的提升,更有赖于软硬一体的系统化能力建设。在MDDC 2025大会上,联发科整合发布AI游戏两大核心场景下的开发平台:Neuron Studio打通模型开发全流程;Dimensity Profiler从多个维度提…...

edge 更新到135后,Clash 打开后,正常网页也会自动跳转

发现了一个有意思的问题:edge 更新135后,以前正常使用的clash出现了打开deepseek也会自动跳转: Search Resultshttps://zurefy.com/zu1.php#gsc.tab0&gsc.qdeepseek ,也就是不需要梯子的网站打不开了,需要的一直正…...

Socket多路复用网络编程应用总结

Socket多路复用网络编程应用总结 概述 • 传统I/O模型的局限性:传统阻塞式I/O模型每次仅在一个文件描述符(File Descriptor, FD)上执行I/O操作,导致程序需等待单个操作完成,无法高效处理多连接场景(如高并…...

APT攻击阶段划分,每个阶段分区方法

根据现有资料,APT(高级持续性威胁)攻击的阶段划分主要基于两种主流模型:洛克希德-马丁的杀伤链模型和生命周期模型。以下是分阶段详解及分区依据: 一、洛克希德-马丁杀伤链模型(7阶段) 核心逻辑…...

图像颜色空间对比(Opencv)

1. 颜色转换 import cv2 import matplotlib.pyplot as plotimg cv2.imread("tmp.jpg") img_r cv2.cvtColor(img, cv2.COLOR_BGR2RGB) img_g cv2.cvtColor(img, cv2.COLOR_BGR2GRAY) img_h cv2.cvtColor(img, cv2.COLOR_BGR2HSV) img_l cv2.cvtColor(img, cv2.C…...

【NLP 58、利用trl框架训练LLM】

孤独总比忍受傻逼好得多 —— 25.4.11 源代码网页: 项目文件预览 - trl:Train transformer language models with reinforcement learning. - GitCode TRL —— 变压器强化学习 trl:一个用于后训练基础模型的全面库 1.概述 TRL 是一个利用监督微调&a…...

数据仓库元数据的管理

元数据(Meta Date),主要记录数据仓库中模型的定义、各层级间的映射关系、监控数据仓库的数据状态 及ETL的任务运行状态。一般会通过元数据资料库(Metadata Repository)来统一地存储和管理元数据,其主要 目的…...

MySQL逻辑架构有什么?

1. MySQL逻辑架构分层 MySQL的逻辑架构可分为三层(自上而下): 连接层(Client Layer)服务层(Server Layer)存储引擎层(Storage Engine Layer) -----------------------…...

蓝桥杯 web 常用到的一些知识点

reduce 方法遍历数组、将数组元素累计 ①reduce接收两个参数,一个回调函数,一个初始值 ②回调函数传递了两个参数,一个是累加值,另一个是当前值 reduce的写法: arrays.reduce((a,c&#xff…...

构建高可靠C++服务框架:从日志系统到任务调度器的完整实现

构建高可靠C服务框架:从日志系统到任务调度器的完整实现 一、深度解析示例代码技术体系 1.1 日志系统的进阶应用 示例代码中的ZRY_LOG_XXX宏展示了基础日志功能,但在生产环境中我们需要更完善的日志系统: 推荐技术栈组合: sp…...

<C#>在 C# .NET 中,使用 LoggerExtensions方法创建日志

在 C# .NET 中,LoggerExtensions 是 Microsoft.Extensions.Logging 命名空间下的一组扩展方法,它们为 ILogger 接口提供了便捷的日志记录方式。借助这些扩展方法,你能轻松记录不同级别的日志,如调试信息、信息、警告、错误等。下面…...

微服务与Spring Cloud Alibaba简介

微服务(或微服务架构)是一种云原生架构方法,其中单个应用程序由许多松散耦合且可独立部署的较小组件或服务组成。本单元主要介绍微服务架构的定义、微服务的特征、微服务架构面临的挑战、Spring Cloud 定义、Spring Cloud 核心组件、Spring C…...

元生代品牌建设:平台实现工作流(comfyui)创建与技术文档说明

本文摘要:蓝耘科技自2004年成立以来,从传统IT系统集成业务转型为聚焦GPU算力云服务的科技公司。其发布的元生代平台,是一个集算力调度、应用市场和AI协作开发为一体的智算云平台。用户可在蓝耘平台使用ComfyUI进行AI绘图,通过添加…...

无线通信网

1.2.4G相邻信道间有干扰,5G相邻信道几乎无干扰 2.2.4G频段的优点是信号强,衰减小,穿墙强,覆盖距离远;缺点是带宽较窄,速度较慢,干扰较大。 5G频段的优点是带宽较宽,速度较快&#…...

WMware虚拟机Ubuntu磁盘扩容

VMware中操作: 选择要扩容的虚拟机,点击编辑虚拟机设置 打开后点击磁盘——>点击扩展(注意:如果想要扩容的话需要删除快照) 调整到你想要的容量 点击上图的扩展——>确定 然后我们进到虚拟机里面 首先&#…...

vscode头文件自由跳转

文章目录 1. 安装c/c扩展2. 建.vscode文件夹 当你想要ctl鼠标左击跳转到三方库的定义的时候请往下看。 1. 安装c/c扩展 2. 建.vscode文件夹 在.vscode文件夹下新建c_cpp_properties.json {"configurations": [{"name": "Linux","include…...

BUG:Cannot find implementation for xxx. database. xxx. xxx_Impl does not exist

问题背景 使用Jetpack Compose将数据存储在room本地数据库时,编译报错: java. lang. RuntimeException: Cannot find implementation for com. example. androidproject. practice. roomdmeo. database. AppDatabase. AppDatabase_Impl does not exist …...

基于PySide6与pyCATIA的工程图智能文本替换工具开发指南

一、需求背景与实现价值 在汽车、航空等制造领域,CATIA工程图的文本标注管理常面临批量修改需求。传统手工操作存在效率低、易出错等问题。本文实现的文本替换工具具有以下行业价值: 提升图纸修订效率(单次操作可处理数千个文本对象&#x…...

MCP协议下人工智能康复理疗智械融合编程方向分析

一、引言:AI 康复时代的技术革新 在全球人口老龄化进程加速以及慢性病发病率持续走高的双重背景下,康复医疗领域正面临着前所未有的需求增长压力。据世界卫生组织(WHO)相关数据表明,预计到 2050 年,全球 60 岁及以上老年人口数量将激增至 21 亿,这一庞大群体中,绝大多…...

【嵌入式硬件】LAN9253说明书(中文版)

目录 1.介绍 1.1总体介绍 1.2模式介绍 1.2.1微控制器模式: 1.2.2 扩展模式 1.2.3 数字IO模式 1.2.4 各模式图 2.引脚说明 2.1 引脚总览 2.2 引脚描述 2.2.1 LAN端口A引脚 2.2.2 LAN端口B引脚 2.2.3 LAN端口A和、B电源和公共引脚 2.2.4 SPI/SQI PINS 2.2.5 分布式时…...

Java学习手册:Java基本语法与数据类型

Java语言以其简洁明了的语法和强大的数据类型系统而闻名。掌握Java的基本语法和数据类型是成为一名合格Java开发者的第一步。本文将深入探讨Java的基本语法结构和数据类型,帮助读者打下坚实的基础。 Java的基本语法 Java语言的语法设计简洁而强大,强调…...

操作系统 3.4-段页结合的实际内存管理

段与页结合的初步思路 虚拟内存的引入: 为了结合段和页的优势,操作系统引入了虚拟内存的概念。虚拟内存是一段地址空间,它映射到物理内存上,但对用户程序是透明的。 段到虚拟内存的映射: 用户程序中的段首先映射到虚…...

金融简单介绍及金融诈骗防范

在当今社会,金融学如同一股无形却强大的力量,深刻影响着我们生活的方方面面。无论是个人的日常收支、投资理财,还是国家的宏观经济调控,都与金融学紧密相连。​ 一、金融学的概念​ 金融学,简单来说,是研…...

基于docker搭建redis集群环境

在redis目录下创建redis-cluster目录&#xff0c;创建docker-compose.yml文化和generate.sh文件 【配置generate.sh文件】 for port in $(seq 1 9); \ do \ mkdir -p redis${port}/ touch redis${port}/redis.conf cat << EOF > redis${port}/redis.conf port 6379 …...

CSS 中常见的布局相关属性及其功能分类

一、块级布局&#xff08;Block Layout&#xff09; 1. display 作用&#xff1a;定义元素的显示方式。常用值&#xff1a; block&#xff1a;块级元素&#xff0c;默认独占一行。inline&#xff1a;行内元素&#xff0c;与其他内容在同一行显示。inline-block&#xff1a;兼…...

用css画一条弧线

ui里有一条弧线&#xff0c;现在用css实现 关键代码 border-bottom-left-radius: 100% 7px 两个参数分别代表横向和纵向的深度border-bottom-right-radius: 100% 7px...

CesiumForUnreal 本地矢量文件的加载,支持 shp/geojson 等常用格式

实现效果 Cesium for Unreal 集成 GDAL、LibPng 实现加载本地矢量文件 实现步骤 添加依赖在 cesium-unreal 中 extern -> cesium-native -> CMakeLists.txt 中的 57 行添加依赖库,代码如下: set(PACKAGES_PRIVATEabseil draco ktx modp-base64 meshoptimizer openssl …...

面向基于发布-订阅的物联网网络的匿名 MQTT 分析

中文标题&#xff1a; 面向基于发布-订阅的物联网网络的匿名 MQTT 分析 英文标题&#xff1a; An Analysis of Anonymous MQTT for Publish-Subscribe-Based IoT Networks 作者信息 Yudai Fukushima&#xff1a;东京都立大学电气工程与计算机科学系硕士生&#xff0c;研究方向…...

<C#> 详细介绍.NET 依赖注入

在 .NET 开发中&#xff0c;依赖注入&#xff08;Dependency Injection&#xff0c;简称 DI&#xff09;是一种设计模式&#xff0c;它可以增强代码的可测试性、可维护性和可扩展性。以下是对 .NET 依赖注入的详细介绍&#xff1a; 1. 什么是依赖注入 在软件开发里&#xff0…...

批量给文件编排序号,支持数字序号及时间日期序号编排文件

当我们需要对文件进行编号的时候&#xff0c;我们可以通过这个工具来帮我们完成&#xff0c;它可以支持从 001 到 100 甚至更多的数字序号编号。也可以支持按照日期、时间等方式对文件进行编号操作。这是一种操作简单&#xff0c;处理起来也非常的高效文件编排序号的方法。 工作…...

乳腺癌识别:双模型融合

​本文为为&#x1f517;365天深度学习训练营内部文章 原作者&#xff1a;K同学啊​ import matplotlib.pyplot as plt import tensorflow as tf import warnings as w w.filterwarnings(ignore) # 支持中文 plt.rcParams[font.sans-serif] [SimHei] # 用来正常显示中文标签 …...

ubuntu 22.04配置cuda和cudnn

cuda&#xff1a;12.1 wget https://developer.download.nvidia.com/compute/cuda/12.1.1/local_installers/cuda_12.1.1_530.30.02_linux.run sudo sh cuda_12.1.1_530.30.02_linux.runAbort/Continue选择Continue&#xff0c;不要勾选自带的driver 配置环境变量。~/.bashrc e…...

为什么Java不支持多继承?如何实现多继承?

一、前言 Java不支持多继承&#xff08;一个类继承多个父类&#xff09;主要出于文中设计考虑&#xff1b;核心目的是简化语言复杂性并避免潜在的歧义性问题。 二、直接原因&#xff1a;菱形继承/钻石继承问题&#xff08;Diamond Problem&#xff09; 假设存在如下继承关系&…...

ESP32S3 链接到 WiFi

以下是关于如何让 ESP32S3 连接到 WiFi 的完整流程和代码示例&#xff1a; ESP32S3 链接到 WiFi 1. 设置工作模式 ESP32 可以工作在两种模式下&#xff1a; Station (STA) 模式&#xff1a;作为无线终端连接到无线接入点&#xff08;AP&#xff09;&#xff0c;类似于手机或…...

AndroidTV D贝桌面-v3.2.5-[支持文件传输]

AndroidTV D贝桌面 链接&#xff1a;https://pan.xunlei.com/s/VONXSBtgn8S_BsZxzjH_mHlAA1?pwdzet2# AndroidTV D贝桌面-v3.2.5[支持文件传输] 第一次使用的话&#xff0c;壁纸默认去掉的&#xff0c;不需要按遥控器上键&#xff0c;自己更换壁纸即可...

在spark中,窄依赖算子map和filter会组合为一个stage,这种情况下,map和filter是在一个task内进行的吗?

在 Spark 中&#xff0c;当 map 和 filter 这类窄依赖&#xff08;Narrow Dependency&#xff09;的算子连续应用时&#xff0c;它们会被合并到同一个 Stage 中&#xff0c;并且在同一个 Task 内按顺序执行。这种优化称为 流水线&#xff08;Pipeline&#xff09;执行&#xff…...

展讯android15源码编译之apk单编

首先找到你要单编的apk生成的路径&#xff1a; sys\out_system\target\product\ussi_arm64\system_ext\app\HelloDemo\HelloDemo.apk接着打开下面这个文件&#xff1a; sys\out_system\ussi_arm64_full-userdebug-gms.system.build.log在里面找关键字"Running command&q…...

EtherCAT 转 ModbusTCP 网关

一、功能概述 1.1 设备简介 本产品是 EtherCAT 和 Modbus TCP 网关&#xff0c;使用数据映射方式工作。 本产品在 EtherCAT 侧作为 EtherCAT 从站&#xff0c;接 TwinCAT 、 CodeSYS 、 PLC 等&#xff1b;在 ModbusTCP 侧做为 ModbusTCP 主站&#xff08; C…...

SpringBoot集成阿里云文档格式转换实现pdf转换word,excel

一、前置条件 1.1 创建accessKey 如何申请&#xff1a;https://help.aliyun.com/zh/ram/user-guide/create-an-accesskey-pair 1.2 开通服务 官方地址&#xff1a;https://docmind.console.aliyun.com/doc-overview 未开通服务时需要点击开通按钮&#xff0c;然后才能调用…...

大数据-271 Spark MLib - 基础介绍 机器学习算法 线性回归 场景 定义 损失 优化

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; Java篇开始了&#xff01; MyBatis 更新完毕目前开始更新 Spring&#xff0c;一起深入浅出&#xff01; 目前已经更新到了&#xff1a; H…...

ubuntu不生成core文件的处理

1、设置unlimited ulimit -a 查看是否设置&#xff0c;没有设置的使用下面命令设置 ulimit -c unlimited这个设置只在当前会话有效&#xff0c;添加到 ~/.bashrc 中&#xff0c;重开终端生效 2、sysctl配置 修改 /etc/sysctl.conf 文件 &#xff0c;增加以下两个配置&#…...

游戏服务器DDoS攻防实战指南——从攻击溯源到智能防护体系构建

本文深度解析游戏行业DDoS攻防技术演进路线&#xff0c;基于等保2.0与NIST框架&#xff0c;从攻击流量识别、弹性防护架构、智能调度算法三大维度&#xff0c;揭示游戏服务器防护体系的23个关键控制点。通过近期《永劫无间》服务器瘫痪事件复盘&#xff0c;结合Gartner最新混合…...

JAVA 导出 word

1、模板方式导出 1.1、引入 maven 依赖 <dependency><groupId>com.deepoove</groupId><artifactId>poi-tl</artifactId><version>1.12.2</version> </dependency>1.2、导出文档代码 public static void main(String[] args…...

OpenHarmony 5.0版本视频硬件编解码适配

一、简介 Codec HDI&#xff08;Hardware Device Interface&#xff09;对上层媒体服务提供视频编解码的驱动能力接口&#xff0c;主要功能有获取组件编解码能力&#xff0c;创建、销毁编解码器对象&#xff0c;启停编解码器操作&#xff0c;编解码处理等。 Codec HDI 2.0接口…...

《Python星球日记》第23天:Pandas基础

名人说&#xff1a;路漫漫其修远兮&#xff0c;吾将上下而求索。—— 屈原《离骚》 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 订阅专栏&#xff1a;《Python星球日记》 目录 一、Pandas 简介1. 什么是 Pandas&…...