qt在不同系统上读写文件以二进制数据流处理数据时严重注意问题0x0a变成0x0d 0x0a问题!

一、前言

如标题,注意注意在注意,不然就是坑

二、环境

window,linux,qt5.7 

三、正文

不论是用qt还是其他环境的程序,通用的问题,在以数据流读写数据时,会发生严重的人工智障问题,就是自动将0x0a变成0x0d 0x0a,一个字节变成了两个字节,坑吧

下面对比前后,需要修正的方式

1.使用QDataStream读写二进制数据时

写:

file.open(QIODevice::WriteOnly|QIODevice::Append);//打开文件,若不存在则新建,若存在则继续后面写入

注:这里一定要把QIODevice::Text去掉,否则系统默认以文本的方式去操作,遇见0x0a就会自动补0x0d,因为他要将“/n”改为“/r/n” 

读:

file.open(QIODevice::ReadOnly);//打开文件

注:同上

2.使用fwrite读写二进制数据时

写:

fopen(filename,"ab+")//以二进制流方式写入,读取同样以二进制流读出,防止回车换行符号等

注:这里一定要带b,如果原生是a,那么就写ab,如果原生是a+,就写ab+,否则系统默认以文本的方式去操作,遇见0x0a就会自动补0x0d,因为他要将“/n”改为“/r/n” 

读:

fopen(filename,"rb")//打开一个文本文件,文件必须存在,只允许读,rb是以二进制流读取,这样读取到0x1a就不错返回0,原封不动的将数据读取出来,r是以文本读取,遇到0x1a会读取成为0,从而导致后面数据乱码

注:这里一定要带b,如果原生是a,那么就写ab,如果原生是a+,就写ab+,否则系统默认以文本的方式去操作,遇见0x0a就会自动补0x0d,因为他要将“/n”改为“/r/n” 

3.暂时只踩到上面两个坑, 后续有坑踩到了在埋吧~

四、结语

Guess you like

Origin blog.csdn.net/qq_37603131/article/details/118315339