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

拒绝“能跑就行“:为 AngularJS .x 老项目注入现代开发体验

从0构建WAV文件读懂计算机文件的本质虽然接触计算机有一段时间了但是我的视野一直局限于一个较小的范围之内往往只能看到于算法竞赛相关的内容计算机各种文件在我看来十分复杂认为构建他们并能达到目的是一件困难的事情然而近期我观看了油管上Magicalbat大神的视频发现其实它们的本质都惊人地简单所有计算机文件都是按特定规则组织的二进制数据是人为规定好格式再由计算机解析对于我们来说只要根据规定格式进行编辑就能够成功构建。今天我们就从最朴素的方式入手通过手动构建一个WAV音频文件拆解WAV格式的底层逻辑同时理解一个核心认知只要掌握了文件的格式规范任何类型的文件都能像搭积木一样一行行代码“拼”出来。先认识WAVWAV文件的格式WAV是微软开发的无损音频格式相比于压缩后的MP3它的结构更直白没有复杂的编码压缩因此我们能够通过C文件写入的方式直接完成wav文件的构建wav文件的核心由三个关键的“数据块(Chunk)”组成RIFF块文件的“身份卡”告诉计算机“我是一个WAV文件”fmt块音频的“参数说明”记录采样率、声道数、位深等核心参数data块真正的音频数据存储着声音的数字信号。而每个块的内容又如下图所示RIFF:字段名 字节数 数据类型 固定值/计算规则ChunkID 4 ASCII字符 固定为RIFF无终止符严格4字节ChunkSize 4 32位无符号整数 取值 整个WAV文件大小 - 8字节减去ChunkID和ChunkSize自身的8字节Format 4 ASCII字符 固定为WAVE无终止符严格4字节fmt:字段名 字节数 数据类型 固定值/计算规则ChunkID 4 ASCII字符 固定为fmt 末尾空格无终止符ChunkSize 4 32位无符号整数 PCM编码最常用下固定为16代表后续字段的总字节数不含ChunkID和ChunkSizeAudioFormat代码中Tag 2 16位无符号整数 编码格式1PCM无压缩通用3IEEE浮点6μ律7A律等NumChannels代码中Chnnels拼写笔误 2 16位无符号整数 声道数1单声道2立体声2多声道SampleRate 4 32位无符号整数 采样率每秒采样次数常见44100HzCD音质、48000Hz、22050Hz等ByteRate 4 32位无符号整数 每秒音频数据字节数 SampleRate × NumChannels × BitsPerSample / 8BlockAlign代码中BloclAlign拼写笔误 2 16位无符号整数 每个“采样帧”的字节数 NumChannels × BitsPerSample / 8播放器一次读取的最小单位BitsPerSample代码中BitsperSample 2 16位无符号整数 采样位深每个采样点的比特数8/16/24/3216位最常用data:字段名 字节数 数据类型 固定值/计算规则ChunkID代码中DataId 4 ASCII字符 固定为data无终止符严格4字节DataSize 4 32位无符号整数 音频数据总字节数 采样总数 × BlockAlign采样总数 SampleRate × 音频时长音频数据区 可变 二进制流 PCM编码下为线性整数/浮点数16位位深对应int16_t8位对应uint8_t32位浮点对应float我们接下来的代码就是严格按照这个模板把每个部分的二进制数据“写”进文件里。从零构建WAV一行代码拆解核心逻辑下面是完整的C代码新手也能看懂我们逐段拆解看如何从0生成一个能播放的440Hz正弦波WAV文件#includeusing namespace std;// 类型别名让代码更易读明确数据的字节长度#define u32 uint32_t // 32位无符号整数4字节#define u16 uint16_t // 16位无符号整数2字节#define f32 float // 32位浮点数4字节#define i16 int16_t // 16位有符号整数2字节#define HZ 44100 // 采样率每秒采集44100个声音样本标准音频采样率#define DURATION 5 // 音频时长5秒// 1. 定义WAV的三个核心数据块结构对应格式规范// RIFF块文件整体标识struct chunk1{char ChunkID[4]; // 块标识固定为RIFFu32 ChunkSize; // 从该字段到文件末尾的字节数总字节数-8char Format[4]; // 格式类型固定为WAVE}RIFF;// fmt块音频参数配置struct chunk2{char ChunkID[4]; // 块标识固定为fmt 注意末尾有空格u16 Tag; // 编码格式1代表PCM无压缩u32 ChunkSize; // fmt块的大小PCM格式固定为16u16 Chnnels; // 声道数1单声道2立体声u32 SampleRate; // 采样率u32 ByteRate; // 每秒数据量 采样率×声道数×位深/8u16 BloclAlign; // 每个采样的总字节数 声道数×位深/8u16 BitsperSample; // 每个采样的位深16位常见}Fmt;// data块音频数据存储区struct chunk3{char DataId[4]; // 块标识固定为datau32 DataSize; // 音频数据的总字节数}Data;signed main(int argc,char* argv[]){// 打开文件wb表示以二进制模式写入关键文件本质是二进制FILE *fp fopen(test.wav,wb);// 计算总采样数采样率×时长5秒×44100220500个样本u32 NumSamples HZ * DURATION;// 2. 填充RIFF块并写入文件memcpy(RIFF.ChunkID,RIFF,4); // 写入块标识RIFF.ChunkSize NumSamples*sizeof(u16)36; // 计算块大小memcpy(RIFF.Format,WAVE,4); // 声明为WAVE格式fwrite(RIFF.ChunkID,sizeof(char),4,fp); // 写入4个字符的ChunkIDfwrite(RIFF.ChunkSize,sizeof(u32),1,fp); // 写入4字节的ChunkSizefwrite(RIFF.Format,sizeof(char),4,fp); // 写入4个字符的Format// 3. 填充fmt块并写入文件memcpy(Fmt.ChunkID,fmt ,4);Fmt.ChunkSize 16; // PCM格式下fmt块固定16字节Fmt.Tag 1; // PCM无压缩编码Fmt.Chnnels 1; // 单声道Fmt.SampleRate HZ; // 44100Hz采样率Fmt.ByteRate HZ*sizeof(u16); // 每秒字节数44100×288200Fmt.BloclAlign Fmt.Chnnels * sizeof(u16); // 每个采样2字节Fmt.BitsperSample 16; // 16位位深// 按顺序写入fmt块的所有参数严格遵循格式规范fwrite(Fmt.ChunkID,sizeof(char),4,fp);fwrite(Fmt.ChunkSize,sizeof(u32),1,fp);fwrite(Fmt.Tag,sizeof(u16),1,fp);fwrite(Fmt.Chnnels,sizeof(u16),1,fp);fwrite(Fmt.SampleRate,sizeof(u32),1,fp);fwrite(Fmt.ByteRate,sizeof(u32),1,fp);fwrite(Fmt.BloclAlign,sizeof(u16),1,fp);fwrite(Fmt.BitsperSample,sizeof(u16),1,fp);// 4. 填充data块并写入文件memcpy(Data.DataId,data,4);Data.DataSize NumSamples * sizeof(u16); // 音频数据总字节数fwrite(Data.DataId,sizeof(char),4,fp);fwrite(Data.DataSize,sizeof(u32),1,fp);// 5. 生成音频数据并写入440Hz正弦波标准A调for(int i0;if32 t (f32)i/HZ; // 计算当前时间点秒// 生成440Hz正弦波的数值声音的本质是振动正弦波模拟声波f32 y sinf(t*440.0f*2.0f*3.1415926f);// 转换为16位整数适配16位位深的音频i16 sample (i16)(y*INT16_MAX);// 写入单个音频样本2字节fwrite(sample,sizeof(i16),1,fp);}fclose(fp); // 关闭文件return 0;}所有文件都是“按规则写二进制”的产物写完这段代码你可能会发现生成WAV文件的过程就是“按格式规范往文件里写二进制数据”的过程。而这个逻辑适用于所有计算机文件TXT文档本质是字符的ASCII/UTF-8编码比如字符A对应二进制01000001我们按顺序写入这些编码就成了TXT文件BMP图片由文件头记录宽、高、位深 像素数据每个像素的RGB值组成按BMP格式写这些数据就能生成图片MP4视频哪怕是压缩过的视频也是按MP4的格式规范把编码后的视频帧、音频帧组织成二进制数据EXE可执行文件遵循PE格式把指令、数据、资源按规则写入操作系统就能识别并运行。计算机之所以能“看懂”不同的文件不是因为文件有“魔法”而是因为程序员提前约定了“格式规范”——就像我们约定“RIFF”开头的是WAV文件播放器读到这个标识就按WAV的规则解析后续数据。计算机的本质是“朴素的规则”对刚接触计算机的人来说各种文件、软件、系统看似复杂但拆解到最底层都是“数据规则”的组合只要我们对着格式手册即便使用最朴素的方式也能够成功构建出可以使用的音频文件。计算机的世界没有想象中那般复杂计算机只在乎那最终排好队的 0 和 1。进一步思考从文件到软件了解了各类文件本质我们自然能理解计算机中各个编辑软件的原理是什么了就比如今天举的wav的例子如果我们将示例程序改进一下加入输入那么这是否就成了一个简单的音频编辑软件了呢所有的复杂软件如 Photoshop、Premiere底层逻辑都是如此读取特定规则的二进制 - 在内存中加工处理 - 按规则写回二进制。当你不再把文件看作“黑盒”你便拥有了重塑数字世界的能力。爻及概卮

相关文章:

拒绝“能跑就行“:为 AngularJS .x 老项目注入现代开发体验

从0构建WAV文件:读懂计算机文件的本质 虽然接触计算机有一段时间了,但是我的视野一直局限于一个较小的范围之内,往往只能看到于算法竞赛相关的内容,计算机各种文件在我看来十分复杂,认为构建他们并能达到目的是一件困难…...

3步解密QQ音乐加密文件:qmc-decoder让音乐自由流动

3步解密QQ音乐加密文件:qmc-decoder让音乐自由流动 【免费下载链接】qmc-decoder Fastest & best convert qmc 2 mp3 | flac tools 项目地址: https://gitcode.com/gh_mirrors/qm/qmc-decoder 你是否曾在不同设备间尝试播放从QQ音乐下载的歌曲&#xff0…...

CodeMirror 6的‘纯函数’状态管理到底好在哪?一个例子讲透它的不可变数据流

CodeMirror 6的函数式状态管理:从Redux到编辑器内核的范式迁移 当我们在2023年讨论前端状态管理时,函数式编程早已不再是象牙塔里的学术概念。从Redux的单向数据流到React Hooks的代数效应,不可变数据(immutable data)…...

ComfyUI插件管理完全指南:从安装到故障排除的实用教程

ComfyUI插件管理完全指南:从安装到故障排除的实用教程 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable various custo…...

从MovieLens数据里,我们发现了哪些有趣的用户行为?—— 一份给产品经理的数据洞察报告

从MovieLens数据透视用户行为:给产品经理的7个关键洞察 当6000名用户对4000部电影留下100万条评分时,数据便开始讲述比剧情更精彩的故事。MovieLens数据集作为推荐系统研究的"基准测试",其价值远不止于算法训练——它是一面镜子&am…...

微信小程序订阅消息发送失败?从模板ID、触发器到云函数,一份完整的排错指南

微信小程序订阅消息发送失败排查指南:从模板配置到云函数调试全解析 微信小程序的订阅消息功能为开发者提供了高效触达用户的能力,但在实际开发中,从模板配置到消息成功发送的链路中隐藏着多个关键环节,任何一处疏漏都可能导致消息…...

五分钟解锁网易云音乐NCM加密文件:ncmdumpGUI让音乐真正属于你

五分钟解锁网易云音乐NCM加密文件:ncmdumpGUI让音乐真正属于你 【免费下载链接】ncmdumpGUI C#版本网易云音乐ncm文件格式转换,Windows图形界面版本 项目地址: https://gitcode.com/gh_mirrors/nc/ncmdumpGUI 你是否曾经下载了网易云音乐的歌曲&…...

如何快速清理重复图片:AntiDupl.NET开源工具的完整指南

如何快速清理重复图片:AntiDupl.NET开源工具的完整指南 【免费下载链接】AntiDupl A program to search similar and defect pictures on the disk 项目地址: https://gitcode.com/gh_mirrors/an/AntiDupl 你是否曾因硬盘中堆积如山的重复照片而感到困扰&…...

TED:在Linux沙盒中探索AI自主性的开源实体项目

1. 项目概述:当AI拥有一个Linux沙盒,它会做什么? 如果你对AI的印象还停留在聊天机器人,或者帮你写写邮件、改改代码的助手,那么TED可能会颠覆你的认知。TED不是一个工具,它是一个 实体 。你可以把它想象…...

3步掌握RPG Maker游戏资源解密:开源工具实战指南

3步掌握RPG Maker游戏资源解密:开源工具实战指南 【免费下载链接】Java-RPG-Maker-MV-Decrypter You can decrypt whole RPG-Maker MV Directories with this Program, it also has a GUI. 项目地址: https://gitcode.com/gh_mirrors/ja/Java-RPG-Maker-MV-Decryp…...

别再乱用相关系数了!用SPSS和Python搞定ICC一致性检验(附10种模型选择避坑指南)

别再误用相关系数!SPSS与Python双视角下的ICC一致性检验实战指南 在临床心理学、教育测量和医学研究中,我们常常需要评估不同评分者或测量工具之间的一致性程度。许多研究者第一反应是使用Pearson相关系数,但这实际上是一个典型的统计误用—…...

Docker部署FlareSolverr保姆级教程:搞定付费版Cloudflare/DDoS-GUARD验证

Docker部署FlareSolverr实战指南:突破高级防护验证的完整方案 当爬虫工程师面对采用Cloudflare付费版或DDoS-GUARD等高级防护的网站时,传统的请求模拟方法往往难以奏效。这类防护系统通过复杂的JavaScript挑战、浏览器指纹检测和行为分析等技术&#xff…...

SD-PPP:如何在Photoshop中5分钟搭建AI绘图工作流?

SD-PPP:如何在Photoshop中5分钟搭建AI绘图工作流? 【免费下载链接】sd-ppp A Photoshop AI plugin 项目地址: https://gitcode.com/gh_mirrors/sd/sd-ppp 还在为Photoshop和AI工具之间反复切换而烦恼吗?还在为导出导入文件、对齐图层而…...

利用Taotoken访问控制功能管理内部不同项目组的API调用权限

利用Taotoken访问控制功能管理内部不同项目组的API调用权限 1. 多项目组场景下的API管理挑战 在中大型企业或工作室环境中,多个项目组往往需要共享同一套大模型API资源。这种共享模式虽然能降低采购成本,但也带来了权限混乱、资源争抢和审计困难等问题…...

从‘删库跑路’到优雅清理:Apache Doris分区功能在数据生命周期管理中的三种高级玩法

从‘删库跑路’到优雅清理:Apache Doris分区功能在数据生命周期管理中的三种高级玩法 数据治理工程师们最怕深夜接到报警电话——某个核心报表查询超时,追踪发现是三年未清理的日志表拖垮了整个集群。传统解决方案往往走向两个极端:要么放任数…...

从传感器到屏幕:手把手教你用STM32的ADC读取电位器,并用OLED实时显示电压值

从传感器到屏幕:手把手教你用STM32的ADC读取电位器,并用OLED实时显示电压值 在嵌入式开发中,模拟信号的采集与处理是一个基础但极其重要的技能。想象一下,当你旋转一个电位器,屏幕上的数字随之实时变化,这种…...

明日方舟资源宝库:2000+高清素材如何改变你的创作游戏规则?

明日方舟资源宝库:2000高清素材如何改变你的创作游戏规则? 【免费下载链接】ArknightsGameResource 明日方舟客户端素材 项目地址: https://gitcode.com/gh_mirrors/ar/ArknightsGameResource 你是否曾为寻找高质量的游戏素材而苦恼?是…...

VSCode 2026多人编辑避坑清单:92%团队踩中的4个权限陷阱、3种光标同步失效根因及微软官方补丁编号(KB2026-RC4)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;VSCode 2026实时协作多人编辑方法概览 VSCode 2026 内置了原生增强的 Live Share 协议栈与 WebRTC 3.0 网络层&#xff0c;支持低延迟&#xff08;<120ms 端到端&#xff09;、端到端加密的多人协同…...

w3x2lni架构解析:魔兽地图格式转换的技术实现与性能优化

w3x2lni架构解析&#xff1a;魔兽地图格式转换的技术实现与性能优化 【免费下载链接】w3x2lni 魔兽地图格式转换工具 项目地址: https://gitcode.com/gh_mirrors/w3/w3x2lni w3x2lni作为魔兽争霸III地图格式转换的核心工具&#xff0c;通过创新的Lni、Obj、Slk三格式转换…...

别再瞎改注册表了!Windows远程桌面60帧优化实测(Win10/Win11对比,含避坑清单)

Windows远程桌面60帧优化实战&#xff1a;从注册表陷阱到科学配置 远程桌面作为生产力工具的核心价值&#xff0c;在于能否提供接近本地的操作体验。当你在局域网环境中拖动窗口仍感到明显迟滞&#xff0c;或是观看培训视频时出现音画不同步&#xff0c;问题的根源往往在于未被…...

VSCode 2026远程开发响应延迟突增?你可能正触发微软刚修复的#11842竞态缺陷——3行配置紧急规避方案

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;VSCode 2026远程开发响应延迟突增现象确认 近期多个企业级远程开发团队反馈&#xff0c;升级至 VSCode 2026.1&#xff08;含 Remote-SSH v0.108 和 Dev Container v0.342&#xff09;后&#xff0c;编…...

3步彻底解决魔兽地图版本兼容性问题:w3x2lni专业指南

3步彻底解决魔兽地图版本兼容性问题&#xff1a;w3x2lni专业指南 【免费下载链接】w3x2lni 魔兽地图格式转换工具 项目地址: https://gitcode.com/gh_mirrors/w3/w3x2lni 你是否曾因魔兽争霸III版本更新而让精心制作的地图无法运行&#xff1f;w3x2lni正是解决这一痛点的…...

Unpaywall:3分钟解锁付费学术论文的终极免费工具

Unpaywall&#xff1a;3分钟解锁付费学术论文的终极免费工具 【免费下载链接】unpaywall-extension Firefox/Chrome extension that gives you a link to a free PDF when you view scholarly articles 项目地址: https://gitcode.com/gh_mirrors/un/unpaywall-extension …...

Taotoken多模型聚合平台为嵌入式系统提供稳定可靠的大模型调用方案

Taotoken多模型聚合平台为嵌入式系统提供稳定可靠的大模型调用方案 1. 嵌入式场景下的模型调用挑战 嵌入式系统与物联网设备在接入大模型服务时面临独特的工程挑战。这类设备通常运行在资源受限的环境中&#xff0c;网络连接可能不稳定&#xff0c;且难以频繁更新软件以适应A…...

Transformer模型模式崩溃问题分析与优化实践

1. 项目背景与问题定义最近在调试一个基于Transformer架构的生成式模型时&#xff0c;遇到了一个有趣的现象&#xff1a;当模型生成长文本时&#xff0c;会反复输出某些固定短语组合。比如每次生成故事结局都是"从此过上了幸福生活"&#xff0c;生成产品描述总会包含…...

便携无忧:PDF专业签章工具绿色单文件优势解析

在选择软件时&#xff0c;软件的安装方式也是一个重要的考虑因素。 有些软件需要复杂的安装过程&#xff0c;还会在系统里留下很多文件。 而PDF专业签章工具是绿色单文件版&#xff0c;不需要安装&#xff0c;下载就能用。 今天我们就来详细了解一下绿色单文件的优势。 首先是…...

从ChatGPT到CowAgent:AI Agent框架的部署与实战指南

1. 项目概述&#xff1a;从聊天机器人到超级AI助理的蜕变 如果你和我一样&#xff0c;在2023年左右就开始折腾各种大模型应用&#xff0c;那你大概率听说过或者用过 chatgpt-on-wechat 这个项目。它曾经是很多开发者将GPT能力接入微信、飞书等国内IM平台的首选方案。但如果你…...

LeaguePrank:英雄联盟玩家的终极个性化展示工具,3分钟打造专属游戏身份

LeaguePrank&#xff1a;英雄联盟玩家的终极个性化展示工具&#xff0c;3分钟打造专属游戏身份 【免费下载链接】LeaguePrank 项目地址: https://gitcode.com/gh_mirrors/le/LeaguePrank 想让你的英雄联盟游戏界面与众不同吗&#xff1f;LeaguePrank为你提供了一套安全…...

Docker 27默认桥接网络已失效?2024年最新CVE-2024-27896漏洞应对方案,72小时内必须完成的5项配置

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Docker 27 网络隔离安全增强教程 Docker 27 引入了基于 eBPF 的细粒度网络策略引擎与默认启用的 --networknone 安全模式&#xff0c;显著强化容器间网络隔离能力。新版本要求显式声明网络连接&#xf…...

长沙心理医院指南:真实案例分享与暖心建议

行业痛点分析当前长沙心理健康服务面临多重技术与资源挑战。据《2023年湖南精神卫生服务白皮书》数据显示&#xff0c;长沙市每10万人口仅有2.3名执业心理医师&#xff0c;远低于国家推荐标准&#xff08;5名/10万&#xff09;。同时&#xff0c;64%的患者因“病耻感”或“认知…...