昨天写一个读取bmp文件的小程序,出现了一个bug,但是不清楚到底是什么原因。
程序是要读取一个bmp文件然后保存成Bmp文件,我发现读取的时候有小错误,保存的时候也有。保存Bmp的时候居然文件大小比原来的文件大小多了3个字节,这三个字节的差异让图片的内容有了巨大的变化。
后来自己检查才发现自己打开文件时候用的是:fopen(filename,”r+”)
而改成 fopen(filename,”wb”)后程序终于完全正常。补了一下c语言文件操作的课,才恍然大悟。默认的,c语言里面是以文本模式打开文件的,在文本模式下,读取的时候换行符会被转换成回车+换行,而保存的时候会将回车+换行保存成换行。我发现我读取8bit的颜色表的时候这样读取,而8bit位图的颜色表中正好有’0a’这个字符,16进制的’0a’即是10,而这样的’0a’会出现三次,三次都会被解释成回车加上换行,所以读取的时候会溢出,而保存的时候会多出三个字节。
故,所有的操作非文本类文件的程序最好都使用二进制模式打开和保存,否则会出现上述的问题。
参考资料:http://blog.sina.com.cn/s/blog_8c7bf19701010yat.html