示例
wav文件使用小端读取,一次把16进制转为十进制的时候要换位置。如:
遇到:00 77 01 00
先倒序:00 01 77 00
然后转为10进制 0x17700 = 96 000

以这个文件为例,分析每个字节的意思:
52 49 46 46:Riff标志
a6 17 02 00:后面的文件大小为0x000217a6,总文件大小为这个数+8字节
57 41 56 45:wav
//下面是fmt区
66 6d 74 20: fmt
10 00 00 00:16个字节后是data区
01 00:编码格式为pcm
01 00:单声道 , 1是单声道,2是双声道
80 bb 00 00: sample rate ; 采样频率(每秒样本数)为 0xbb80,即48 000HZ。
00 77 01 00: bitssample ratechannels/8 0x00017700 = 96 000. 每秒数据量;其值为通道数×每秒数据位数×每样本的数据位数/8。播放软件利用此值可以估计缓冲区的大小。
02 00: bits*channels/8 0x0002 = 2。数据块的调整数(按字节算的),其值为通道数×每样本的数据位值/8。播放软件需要一次处理多个该值大小的字节数据,以便将其值用于缓冲区的调整。
10 00: bits 0x0010=16。每样本的数据位数,表示每个声道中各个样本的数据位数。如果有多个声道,对每个声道而言,样本大小都一样。
//后面是data区(24H)
64 61 74 61: “data”标志

博客详细解析了一个wav音频文件的内容,包括RIFF区、fmt区和data区的各个字段,如编码格式、采样率、每秒数据量等。还介绍了如何从文件中读取和理解特定的数据段,并展示了实际期望获取的音频样本数据。
6016

被折叠的 条评论
为什么被折叠?



