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

深入探索Linux命名管道(FIFO):原理、实践与高级技巧

引言:跨越进程的“文件桥梁”

在Linux的进程间通信(IPC)机制中,命名管道(Named Pipe,FIFO) 是一个看似简单却功能强大的工具。它不仅保留了匿名管道的流式数据传输特性,还通过文件系统实现了无亲缘关系进程的通信。本文将深入解析其工作原理,揭示实际开发中的最佳实践,并探讨其在现代云原生架构中的独特价值。


一、命名管道的本质剖析
1.1 底层实现机制
  • 内核数据结构

    struct pipe_inode_info {wait_queue_head_t wait;  // 等待队列unsigned int nrbufs;     // 未读缓冲区数struct pipe_buffer bufs[16]; // 环形缓冲区(默认16页)
    };

    • 每个FIFO在内核中维护独立的读写指针

    • 使用VFS(虚拟文件系统)接口实现文件操作

  • 持久化特性

$ mkfifo /tmp/demo.fifo
$ stat /tmp/demo.fifo
File: /tmp/demo.fifo
Size: 0          Blocks: 0          IO Block: 4096   FIFO

 1.2 通信流程详解

sequenceDiagramparticipant Writerparticipant Kernelparticipant ReaderWriter->>Kernel: open(O_WRONLY)Reader->>Kernel: open(O_RDONLY)Writer->>Kernel: write(data)Kernel->>Reader: wakeup via wait queueReader->>Kernel: read(data)Kernel->>Writer: buffer空间释放通知
二、核心操作与高级特性
2.1 创建方式对比
方法示例特点
Shell命令mkfifo /tmp/pipe1快速创建,适合脚本
C标准库mkfifo("pipe2", 0666)精细控制权限
Python os模块os.mkfifo("pipe3")适合Python自动化流程
2.2 非阻塞模式实战
// 写端设置非阻塞
int fd = open(fifo_path, O_WRONLY | O_NONBLOCK);
if (fd == -1) {if (errno == ENXIO) {// 无读端时立即失败}
}// 读端非阻塞轮询
struct pollfd fds = {.fd = fd, .events = POLLIN};
while (poll(&fds, 1, 1000) > 0) {read(fd, buf, size);
}
2.3 多进程通信模式
  • 广播模式:多个读进程同时接收数据

    # 终端1
    echo "Broadcast" > /tmp/multi.fifo# 终端2-3
    cat /tmp/multi.fifo  # 所有终端都收到相同数据

    负载均衡模式:多个写进程竞争写入

    // 使用文件锁保证原子性
    flock(fd, LOCK_EX);
    write(fd, data, len);
    flock(fd, LOCK_UN);
    三、性能优化深度指南
    3.1 缓冲区调优
    # 查看系统级限制
    $ sysctl fs.pipe-max-size
    fs.pipe-max-size = 1048576  # 默认1MB# 动态调整缓冲区(需CAP_SYS_RESOURCE)
    fcntl(fd, F_SETPIPE_SZ, 8*1024*1024);  # 扩展为8MB
    3.2 零拷贝技术应用
    // 使用splice系统调用
    int pipefd[2];
    pipe(pipefd);// 文件到FIFO的零拷贝传输
    splice(file_fd, NULL, fifo_fd, NULL, 4096, 0);
    3.3 性能基准测试
    操作吞吐量 (MB/s)延迟 (μs)CPU占用
    单进程读写6501.218%
    非阻塞多写7201.835%
    大缓冲区(8MB)9800.922%

    四、现代开发场景应用
    4.1 微服务日志收集
    # 日志生产者(Go服务)
    func writeLog() {fifo, _ := os.OpenFile("/var/log/service.fifo", os.O_WRONLY, 0666)fifo.WriteString(logEntry)
    }# 日志消费者(Python)
    with open('/var/log/service.fifo', 'r') as f:for line in f:send_to_elasticsearch(line)
    4.2 Kubernetes Sidecar模式
    apiVersion: v1
    kind: Pod
    metadata:name: log-processor
    spec:containers:- name: appimage: myappvolumeMounts:- name: fifo-volmountPath: /var/log- name: sidecarimage: fluentdvolumeMounts:- name: fifo-volmountPath: /var/logvolumes:- name: fifo-volemptyDir: {}
    4.3 安全加固方案
    # 设置ACL
    setfacl -m u:nginx:rw /var/run/api.fifo# SELinux策略
    allow httpd_t named_pipe_t:file { read write };
    五、经典问题解决方案
    5.1 数据残留处理
    # 清空管道而不阻塞
    dd iflag=nonblock if=/tmp/stuck.fifo of=/dev/null
    5.2 双向通信实现
    # 创建双管道
    mkfifo /tmp/chat.in /tmp/chat.out# 进程A
    exec 3<>/tmp/chat.in
    exec 4</tmp/chat.out# 进程B
    exec 3</tmp/chat.in
    exec 4<>/tmp/chat.out
    5.3 自动重连机制
    import os
    import timedef safe_open(fifo_path, mode):while True:try:return os.open(fifo_path, mode)except OSError as e:if e.errno == errno.ENXIO:time.sleep(0.1)else:raise
    结语:历久弥新的通信艺术

    从1973年Unix V3首次实现FIFO,到如今支撑着Kubernetes Pod的Sidecar通信,命名管道证明了优秀设计的永恒价值。在追求高性能、低延迟的云原生时代,理解这个经典机制不仅能帮助开发者构建高效系统,更能让我们领悟到:真正的技术之美,在于用简单的抽象解决复杂的问题

相关文章:

深入探索Linux命名管道(FIFO):原理、实践与高级技巧

引言&#xff1a;跨越进程的“文件桥梁” 在Linux的进程间通信&#xff08;IPC&#xff09;机制中&#xff0c;命名管道&#xff08;Named Pipe&#xff0c;FIFO&#xff09; 是一个看似简单却功能强大的工具。它不仅保留了匿名管道的流式数据传输特性&#xff0c;还通过文件系…...

光伏政策“430”“531”安科瑞光储充为新能源提供解决方案有哪些?

简婷 安科瑞电气股份有限公司 上海嘉定 201801 一、政策节点“430”与“531”的含义 2025年分布式光伏行业的两大核心节点——“4月30日”&#xff08;430&#xff09;和“5月31日”&#xff08;531&#xff09;&#xff0c;分别对应《分布式光伏发电开发建设管理办法》实施…...

VScode一直处于循环“正在重新激活终端“问题的解决方法

方法一&#xff1a; 键盘使用 “ctrlshiftp” 调出快捷命令&#xff0c;也可以按F1&#xff0c;并输入“>Python: Clear Cache and Reload Window ”&#xff0c;回车。清除 VSCode 先前的缓存内容&#xff0c;如下图所示。 方法二&#xff1a; 键盘使用 ” ctrl ,"…...

CAN报文逆向工程

在没有DBC文件的情况下解析CAN报文获取物理信息需要逆向工程和系统分析。以下是详细步骤&#xff1a; 1. 数据采集与基础分析 采集原始数据&#xff1a; 使用CAN分析工具&#xff08;如PCAN-Explorer、SavvyCAN或USB-CAN适配器配套软件&#xff09;记录车辆在不同状态下的CAN数…...

文件包含漏洞学习

理论 什么是文件包含漏洞 就是允许攻击者包含并执行非预期的文件。也就是通过PHP函数引入文件时&#xff0c;传入的文件名&#xff08;或者文件内容&#xff09;没有经过合理的验证&#xff0c;从而操作了预想之外的文件&#xff0c;就可能导致意外的文件泄漏甚至恶意代码注入…...

Linux基本操作——网络操作文件下载

6.网络操作文件下载 &#xff08;1&#xff09;在VMware Workstation中配置固定IP 配置固定IP需要的两个大步骤 VMware Workstation中的配置 步骤概述&#xff1a;配置IP地址、网关和网段&#xff08;IP地址范围&#xff09; Linux系统中的配置 步骤概述&#xff1a;手动修改…...

【ARM AMBA AHB 入门 3.1 -- AHB控制信号】

文章目录 AHB控制信号传送状态HTRANS[1:0]批量传送HBURST[2:0]传送方向HWRITE传送大小HSIZE[2:0]保护控制HPROT[3:0]响应信号 HRESP[1:0] AHB控制信号 传送状态HTRANS[1:0] 在AHB总线上, Master &#xff08;M&#xff09; 的传送状态可由HTRANS[1:0]来表示,这两位所代表的意…...

Amazing晶焱科技:系统级 EOS 测试方法 - System Level EOS Testing Method

系统上常见的EOS测试端口以AC电源、电话线&#xff08;RJ11&#xff09;、同轴电缆&#xff08;coaxial cable&#xff09;以及以太网络&#xff08;RJ45&#xff09;最常见&#xff0c;这些端口因有机会布线至户外的关系&#xff0c;受到EOS/Surge冲击的几率也大大提升。因此电…...

基于DR模式的LVS集群案例

一.环境描述 如上图所示&#xff0c;后端是一个NFS服务器实现共享文件&#xff0c;调度器是一个高可用的环境&#xff0c; 这是基于LVS的DR模式实现的一个负载均衡集群。 keepalived在于LVS结合使用的时候&#xff0c;会自动实现很多功能。 比如&#xff0c;第一点我们可以修…...

Spark jdbc写入崖山等国产数据库失败问题

随着互联网、信息产业的大发展、以及地缘政治的变化,网络安全风险日益增长,网络安全关乎国家安全。因此很多的企业,开始了国产替代的脚步,从服务器芯片,操作系统,到数据库,中间件,逐步实现信息技术自主可控,规避外部技术制裁和风险。 就数据库而言,目前很多的国产数据…...

Chain-of-Draft (CoD) 是提示工程的新王者

图像由 DALLE 3 生成 推理型大模型&#xff0c;是当前 AI 研究的热门话题。 我们从最早的 GPT-1 一路走到现在像 Grok-3 这样的高级推理模型。 这段旅程可以说非常精彩&#xff0c;过程中也发现了很多重要的推理方法。 其中之一就是 Chain-of-Thought&#xff08;CoT&#xff0…...

隐私计算技术及其在数据安全中的应用:守护数据隐私的新范式

前言 在数字化时代&#xff0c;数据已成为企业和组织的核心资产。然而&#xff0c;数据的收集、存储和使用过程中面临着诸多隐私和安全问题。随着法律法规对数据隐私的监管日益严格&#xff0c;企业和组织需要在数据利用与隐私保护之间找到平衡。隐私计算技术作为一种新兴的数据…...

使用Milvus向量数据库构建具有长期记忆的对话机器人

一、申请Milvus试用版 快速创建Milvus实例_向量检索服务 Milvus 版(Milvus)-阿里云帮助中心 二、配置 pip3 install pymilvus tqdm dashscope 由于在下文使用的时候需要用到Milvus的公网地址&#xff0c;而公网地址需要我们手动开启&#xff0c;参考下面这篇文章开启公网地…...

[Es_1] 介绍 | 特点 | 图算法 | Trie | FST

编程就是一门不断试错的艺术。不要害怕犯错&#xff0c;实践才会出真知。 什么是ElasticSearch&#xff1f; Elasticsearch是一个分布式的免费开源搜索和分析引擎 适用于包括文本、数字、地理空间、结构化和非结构化数据等在内的所有类型的数据。 Elasticsearch在Apache Luc…...

企业安装加密软件有什么好处

企业安装加密软件可以有效保护敏感数据安全&#xff0c;防止信息泄露&#xff0c;并满足合规要求。以下是其主要好处及具体应用场景&#xff1a; 1. 防止数据泄露&#xff0c;保护核心资产 文件加密&#xff1a;对敏感文件&#xff08;如财务数据、客户信息、设计图纸&#xff…...

【MVCP】基于解纠缠表示学习和跨模态-上下文关联挖掘的多模态情感分析

多处可看出与同专栏下的DCCMCI很像 abstract 多模态情感分析旨在从多模态数据中提取用户表达的情感信息,包括语言、声学和视觉线索。 然而,多模态数据的异质性导致了模态分布的差异,从而影响了模型有效整合多模态互补性和冗余性的能力。此外,现有的方法通常在获得表征后直…...

2025软考【系统架构设计师】:两周极限冲刺攻略(附知识点解析+答题技巧)

距离2025上半年“系统架构设计师”考试已经只剩最后两周了&#xff0c;还没有准备好的小伙伴赶紧行动起来。为了帮助大家更好的冲刺学习&#xff0c;特此提供一份考前冲刺攻略。本指南包括考情分析、答题技巧、注意事项三个部分&#xff0c;可以参考此指南进行最后的复习要领&a…...

企业该如何选择合适的DDOS防护?

在互联网行业当中&#xff0c;大型的网络游戏和网络视频企业会经常受到DDOS攻击和CC攻击&#xff0c;这些网络攻击会导致服务器崩溃或者是网络中断&#xff0c;给企业造成巨大的经济损失&#xff0c;所以企业通常会配备合适的DDOS防护来进行防御&#xff0c;但是&#xff0c;对…...

CPU-GPU-NPU-TPU 概念

1.CPU 中央处理器&#xff08;Central Processing Unit&#xff0c;简称CPU&#xff09;作为计算机系统的运算和控制核心&#xff0c;是信息处理、程序运行的最终执行单元。CPU自产生以来&#xff0c;在逻辑结构、运行效率以及功能外延上取得了巨大发展。 2.GPU GPU&#xff0…...

DELL R770 服务器,更换OCP模块!

今天接到客户报修电话&#xff0c;说有一台 DELL PowerEdge R770服务器&#xff0c;网卡出现了故障&#xff0c;需要更换OCP模块。顺便做一个教程&#xff0c;分享给有需要的小伙伴们。 这一期的教程&#xff0c;听起来好像很高大上&#xff0c;很多小伙伴可能不知道OCP是什么…...

go.mod没有自动缓存问题

今天在安装Gin框架的时候遇到了一个问题 在Terminal运行下面命令安装时&#xff0c;包已经被下载安装到了GoPath中的bkg/mod go get -u github.com/gin-gonic/gin但是由于使用的是Go Modules&#xff0c;GPT以及大多数人给的说法是 运行完这个依赖包会被自动同步更新到go.mod…...

黑电平校正(Black Level Correction, BLC)算法

黑电平校正&#xff08;Black Level Correction, BLC&#xff09;算法 黑电平校正&#xff08;BLC&#xff09;是图像传感器&#xff08;如CMOS/CCD&#xff09;信号处理中的一个重要步骤&#xff0c;主要用于消除传感器暗电流&#xff08;Dark Current&#xff09;导致的基线…...

Ubuntu 安装 Keepalived

Keepalived 是什么 Keepalived 是一个用于实现高可用性&#xff08;High Availability, HA&#xff09;的服务&#xff0c;是一款基于 VRRP 协议的高可用软件&#xff0c;常用于主备切换和虚拟IP漂移&#xff0c;在服务故障时自动实现故障转移。 Keepalived 的核心功能 功能说…...

基于SpringBoot和PostGIS的应急运输事件影响分析-以1.31侧翻事故为例

目录 前言 一、技术实现路径 1、需要使用的数据 2、空间分析方法 二、相关模块设计与实现 1、运输路线重现开发 2、事故点影响范围实现 3、WebGIS可视化实现 三、讨论 1、界面结果展示 2、影响范围分析 四、总结 前言 在交通运输发达的当今社会&#xff0c;应急运输…...

ABP-Book Store Application中文讲解 - 前期准备 - Part 2:创建Acme.BookStore + Angular

ABP-Book Store Application中文讲解-汇总-CSDN博客 因为本系列文章使用的.NET8 SDK&#xff0c;此处仅介绍如何使用abp cli .NET 8 SDK SQL sevrer 2014创建Angular模板的Acme.BookStore。 目录 1. ABP cli创建项目 1.1 打开cmd.exe 1.2 创建项目 2. ABP Studio创建项…...

grpc到底是啥! ! !!

一、什么是RPC&#xff08;Remote Procedure Call&#xff09; 简单理解&#xff1a; RPC是一种让程序可以像调用本地函数一样去调用远程机器上的函数或方法。它的目标&#xff1a;让分布式系统中的不同计算机可以透明地互相通信&#xff0c;实现远程服务调用的封装。 举个例…...

ES6入门---第三单元 模块五:Map和WeakMap

map: users.map((user) 遍历 类似 json, 但是json的键(key)只能是字符串 map的key可以是任意类型 使用: let map new Map(); map.set(key,value); 设置一个值 map.get(key) 获取一个值 map.delete(key) 删除一项 map.has(key) 判断有没有 map.clear…...

【C++】【数据结构】【API列表】标准库数据结构

标准库数据结构 unordered_set 头文件&#xff1a;#include <unordered_set>​ 特性&#xff1a; 唯一性&#xff1a;所有元素唯一&#xff0c;重复插入无效无序性&#xff1a;元素存储顺序不固定自定义类型&#xff1a;若存储自定义类型需提供哈希函数和相等比较器 …...

三、Hadoop1.X及其组件的深度剖析

作者&#xff1a;IvanCodes 日期&#xff1a;2025年5月7日 专栏&#xff1a;Hadoop教程 一、Hadoop 1.X 概述 &#xff08;一&#xff09;概念 Hadoop 是 Apache 开发的分布式系统基础架构&#xff0c;用 Java 编写&#xff0c;为集群处理大型数据集提供编程模型&#xff0c;…...

stm32常见错误

1.使用LCD屏幕时&#xff0c;只用st-link时&#xff0c;亮度很暗&#xff0c;需要用usb数据线额外给屏幕供电&#xff1b; 2.移植freertos到f103c8t6芯片时&#xff0c;工程没有错误&#xff0c;但单片机没有反应&#xff1b; 需要将堆的大小改成10*1024&#xff1b; 3.在找已经…...

《Python星球日记》 第46天:决策树与随机森林

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

【Pandas】pandas DataFrame expanding

Pandas2.2 DataFrame Function application, GroupBy & window 方法描述DataFrame.apply(func[, axis, raw, …])用于沿 DataFrame 的轴&#xff08;行或列&#xff09;应用一个函数DataFrame.map(func[, na_action])用于对 DataFrame 的每个元素应用一个函数DataFrame.a…...

【SpringCloud GateWay】Connection prematurely closed BEFORE response 报错分析与解决方案

一、背景 今天业务方调用我们的网关服务报错: Connection prematurely closed BEFORE response二、原因分析 三、解决方案 第一步: 增加 SCG 服务的JVM启动参数,调整连接获取策略。 将连接池获取策略由默认的 FIFO&#xff08;先进先出&#xff09;变更为 LIFO&#xff08…...

【行业】一些名词

名词 分布式应用架构&#xff08;分布式计算技术的应用和工具&#xff09;中间件 中间件&#xff08;Middleware&#xff09;主流中间件技术1.通信类2.数据类3. **协调与治理类中间件**4. 监控与可观测性中间件5.**流处理与批处理**中间件6.云原生中间件 数据库Redismogodb 分布…...

深度学习模型的部署实践与Web框架选择

引言 在深度学习项目的完整生命周期中&#xff0c;模型训练只是第一步&#xff0c;将训练好的模型部署到生产环境才能真正发挥其价值。本文将详细介绍模型部署的核心概念、常见部署方式以及三种主流Python Web框架的对比分析&#xff0c;帮助开发者选择最适合自己项目的技术方…...

【笔记】当个自由的书籍收集者从canvas得到png转pdf

最近有点迷各种古书&#xff0c;然后从 www.shuge.org 下载了各种高清的印本&#xff0c;快成db狂魔了…上面也有人在各种平台上分享&#xff0c;不胜感激…只是有些平台可以免费看但是没法下载… 反正你都canvas了&#xff0c;撸下来自己珍藏… 于是让qwen写了一段代码&#…...

Ubuntu 配置网络接口端点(静态 IP 地址)详细教程

在 Ubuntu 系统中&#xff0c;配置网络接口端点通常指的是为您的有线或无线网卡设置一个固定的 IP 地址、子网掩码、网关以及 DNS 服务器。这对于服务器或者需要稳定网络标识的设备来说非常重要。 使用 Netplan (Ubuntu 17.10 及更高版本的默认方式)使用 ifupdown (通过 /etc/…...

JavaScript ES6+ 最佳实践

1. 变量声明&#xff1a;从 var 到 let/const 问题代码&#xff1a;var 存在变量提升&#xff0c;只有函数作用域&#xff0c;没有块级作用域&#xff0c;容易导致变量污染。 // 变量提升导致意外行为 console.log(num); // undefined 而非报错 var num 10;// 没有块级作用域…...

华为昇腾在智慧矿山机器人的应用及其技术解决方案

一、智慧矿山机器人的核心应用场景 1. ‌井下智能巡检机器人‌ 搭载昇腾AI芯片的巡检机器人可实现 ‌全自主导航与多模态感知‌&#xff0c;通过激光雷达视觉SLAM技术实时构建井下三维地图&#xff0c;精准识别巷道变形、设备漏油等异常状态47。结合昇腾边缘计算能力&#xf…...

发那科机器人3(机器人编程基础)

发那科机器人(机器人编程基础) 一、机器人编程基础1、程序构成2、程序创建3、程序修改4、程序操作5、程序的停止与恢复6、执行程序7、测试运转8、自动运转一、机器人编程基础 1、程序构成 什么是程序? 程序指的是由用户编写的一系列机器人指令以及其他附带信息构成,使机器…...

2014年写的一个文档《基于大数据应用的综合健康服务平台研发及应用示范》

项目目标与任务 项目目标与任务需求分析 当今社会已经处于高度信息化的时代&#xff0c;作为关系民生的重要领域&#xff0c;医疗行业的信息化直接涉及临床服务、社会保障、医学研究和大众健康等环节&#xff0c;对提升医疗服务水平&#xff0c;强化管理职能&#xff0c;改善…...

Python初学者笔记第十一期 -- (字符串编程练习题)

第20节课 【字符串编程练习题】 练习01 回文字符串 输入一个字符串&#xff0c;判断其是否是回文字符串。 # 思路1 # s1 "黄山落叶松叶落山黄" # s2 s1[::-1] # 反转 # print(s2) # print(s1 s2)# 思路2 def is_palindrome(s):l 0r len(s) - 1while l < r…...

[量化交易Backtrader] - 如何规避过拟合

一、回测中的过拟合:隐藏在数据背后的陷阱 过拟合发生在模型过度适应历史数据,以至于在新数据上表现不佳。这就像是为历史数据量身定制了一件衣服,却在新的数据集上穿不进去。 (一)过拟合的常见表现 曲线过于完美 当在回测报告中看到策略的净值曲线如同一条完美的上升直…...

前端日常 · 移动端网页调试

前端日常 移动端网页调试技巧集锦&#xff1a;5个工具 实战思路 在移动端开发中&#xff0c;调试网页内容常常不是“写完就跑”的顺滑体验。尤其当页面跑在 App WebView 里时&#xff0c;不同系统版本、设备特性、浏览器行为都可能带来各种“只有你遇得到”的玄学 Bug。本篇…...

SQLite数据库加密(Java语言、python语言)

1. 背景与需求 SQLite 是一种轻量级的关系型数据库,广泛应用于嵌入式设备、移动应用、桌面应用等场景。为了保护数据的隐私与安全,SQLite 提供了加密功能(通过 SQLCipher 扩展)。在 Java 中,可以使用 sqlite-jdbc 驱动与 SQLCipher 集成来实现 SQLite 数据库的加密。 本…...

【前端基础】6、CSS的文本属性(text相关)

目录内容 text-decoration&#xff1a;设置文本装饰线text-transform&#xff1a;文本中文字的大小写转换text-indent&#xff1a;首行缩进text-align&#xff1a;设置文本对齐方式 一、text-decoration&#xff1a;设置文本装饰线 常见值&#xff1a; None&#xff1a;没有…...

Kafka生产者send方法详解

Kafka生产者send方法详解 1. send方法的工作原理 1.1 基本流程 #mermaid-svg-EXvKiyf8oSlenrxK {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-EXvKiyf8oSlenrxK .error-icon{fill:#552222;}#mermaid-svg-EXvKiyf…...

RPA与After Effects 2024深度融合:自动化影视特效全链路革命

文章目录 一、RPA在影视后期中的核心应用场景1. 跨平台数据自动化采集与预处理2. 动态数据驱动动画&#xff1a;从Excel到AE的无缝衔接 二、After Effects 2024自动化增强技术1. Python脚本深度集成&#xff1a;批量生成三维动画2. 实时渲染优化&#xff1a;智能调度与多分辨率…...

【Python 实战】---- 使用Python批量将 .ncm 格式的音频文件转换为 .mp3 格式

1. 前言 .ncm 格式是网易云音乐专属的加密音频格式,用于保护版权。这种格式无法直接播放,需要解密后才能转换为常见的音频格式。本文将介绍如何使用 Python 批量将 .ncm 格式的音频文件转换为 .mp3 格式。 2. 安装 ncmdump ncmdump 是一个专门用于解密 .ncm 文件的工具。它…...

【上位机——MFC】序列化机制

相关类 CFile-文件操作类&#xff0c;封装了关于文件读写等操作 CFile::Open CFile::Write/Read CFile::Close CFile::SeekToBegin / SeekToEnd / Seek 代码示例 #include <afxwin.h> #include <iostream>using namespace std;void File() {CFile file;file.Ope…...