引子:
最近在读取他人提供的.ini文件的时候,使用先前运行良好的函数怎么也读不到。文件句柄可以得到,就是获取不了想要得到的section value and key value.
文件形如:
[SECTION 1]
Key1=value1
Key2=value2
Key3=value3
查找原因:
1 初步比较
用ultraEdit-32打开,没有发现什么区别。用记事本打开发现先前的文件是
[SECTION 1]
Key1=value1
Key2=value2
Key3=value3
而现在的文件是
[SECTION 1]Key1=value1Key2=value2Key3=value3
这是为什么呢?
2 继续分析
使用ultraEdit-32再次打开先前的文件,选择“编辑/十六进制功能/十六进制编辑”,发现每行的结尾是OD OA。
使用同样的方式打开当前的文件,发现每行的结尾是OA。
3 深入挖掘
OD OA的十进制数分别是13 10,查看ASCII代码对照表,发现13和10分别是CR(carriage return)和LF(line feed),即回车和换行。
4 拨云见日
两个文件的差别:先前的文件使用回车和换行做结尾,现在的文件使用换行做结尾。查看读取文件的函数代码,原来是以回车(13)作为判断一行的结束的,当前的文件中没有回车,函数就不能在适当的位置停下来。难怪我在读取的时候只能获得文件句柄,却无法获得自己想要的值。
5 解决方法
方法一:改写读写函数,以换行符(10)为判断每行结束的标识;
方法二:将当前的文件在每行的末尾加回车,保存即可。
在读取.ini配置文件时遇到问题,函数无法正确获取section和key-value对。通过对比和分析发现,问题在于文件行尾的换行符不同:一个文件使用了回车换行(CR LF),另一个仅使用了换行(LF)。函数设计依赖于回车(CR)来判断行结束,因此无法处理只包含换行符的文件。解决方法包括修改读取函数以适应LF,或者在文件末尾添加回车符。
1192

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



