学习LinuxC的过程中发现一个有趣的现象—— 一般情况下,vim和gedit是相互兼容的,但是有时候,用gedit打不卡vim编辑过的文件。
笔者是从学习lseek()函数的用法时发现这个问题的。off_t lseek(int fd,off_t offset,int whence) 在这个函数中,第一个参数是文件标识符,第二个是偏移量(负数表示向前),第三个参数表示从哪里开始。
其中,第三个参数有一些预定义,其中一个就是SEEK_END,从文件末尾开始,笔者尝试使用后发现,偏移量为3,却实际“读出”两字符。后来vim打开读取的文件发现,在文件末尾有^@,的符号,这个符号本身是没有实际含义的,使用cat命令也无法读取出来,其实是vim中的特殊符号有可能是在调用write函数(没使用O_APPEND)清空文件时所产生的。问题的关键就在于此,此时gedit是无法识别^@(会把存在这样符号的文件当做是二进制文件),gedit是只能打开文本文件的(而vim没有这个限制)这样,打开后它就会报错,除非在vim中删除^@(对于整个文件的完整性是没有影响的)。
值得一提的是,如果你在打开某个文件后发现有大量的^@符号,那你要小心了,这可能是个二进制文件。