不同操作系统对文本文件“行结束符”的不同定义
(http://www.diybl.com/course/3_program/c++/cppsl/20081117/151346.html)
/n是换行,英文是linefeed,ASCII码是0xA。
/r是回车,英文是carriage return,ASCII码是0xD。
如果用过机械打字机,就知道回车和换行的区别了。
换行就是把滚筒卷一格,不改变水平位置。
回车就是把水平位置复位,不卷动滚筒。
但是我们平时按得Enter到底是回车还是换行,不太清楚??
看到一种说法:windows下enter是/n/r,unix下是/n,mac下是/r
在MS的系统中,纯文本格式按一个回车键(不要和这里讨论的回车符混淆)是输入了两个字符,一个回车一个换行。在LINUX系统中则只是一个回车。
Unix系统里,每行结尾只有"<换行>",即"/n";
Windows系统里面,每行结尾是"<换行><回车>",即"/n/r";
Mac系统里,每行结尾是"<回车>"。
一个直接后果是,Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;
而Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。
Linux和其他Unix类操作系统使用单个字符作为行结束符,这个字符通常被称作“换行符”(LF)或“新行”(NL) 。
Dos,Windows和OS2使用两个字符作为行结束符,一个“回车”(CR)和一个LF。
Mac OS只使用一个CR。
有些Linux配置文件对行结束符规范很敏感,所以尽量不要试图从Dos,Windows或Mac OS系统编辑Linux系统的配置文件。
小议Linux与Windows回车换行问题
(http://noding.bokee.com/3867119.html)
所谓回车、换行这些控制符,都是从以前的电传打字机的控制命令继承下来的。回车就是打印头复位,换行就是走纸。
Dos/Windows和Unix/Linux对回车、换行的理解差别就在于 Dos/Windows认为0d=0d0a=0a,而Unix/Linux坚持沿用电传打字机的工作方式(这个其实是比较正确的)。
所以,回车换行在Linux中是"0d"?,在Windows中是"0d0a"。我们可以通过下面的程序测试一下:
#define MAX_LENGTH 15536
#include
#include
using namespace std;
string delEnter(const string src)//过滤掉串中的回车换行符
{
string des;
for(int i = 0; i<src.length(); i++)
{
char tempChar = src[i];
if( tempChar!=10 && tempChar!=13 )
des.append(1, tempChar);
}
return des;
}
int main()
{
char html[MAX_LENGTH] = "";
FILE* fp = fopen("Linux.txt", "rb"); //FILE* fp = fopen("Windows.txt", "rb");
char buf[16384];
while( fgets(buf, 16384, fp) )
strcat(html, buf);
strcat(html, "/0");
string s(html);
cout<<"string is:"<<s<<endl;
cout<<"The size of string is:"<<s.length()<<endl;
cout<<"after del string is:"<<delEnter(s)<<endl;
cout<<"The size of string is:"<<delEnter(s).length()<<endl;
fclose(fp);
return 0;
}
程序中文件Linux.txt是从Linux系统中copy过来的。
我们可以通过这个程序观察到,通过过滤掉回车换行符,Linux文件中的字符数的减少等于其行数,而Windows中等于其行数的两倍。
但是,有一个问题要注意,程序中行:
FILE* fp = fopen("Linux.txt", "rb");//只读打开一个二进制文件
不能写成:
FILE* fp = fopen("Linux.txt", "r");
后者默认的文件打开方式是文本方式,这时系统自动对文本进行了转换,就不能得到上述的结论。
不过大家可以在Windows下用工具HexWorkShop,在Linux下用命令hexdump直接观察具体的二进制代码,更为直接。
参考连接:
求助:回车符与换行符:http://bbs.lehu.shu.edu.cn/Article.aspx?aid=160186
回车符和换行符:http://hi.baidu.com/janicezhu/blog/item/c8ad058ffc4502f0503d9206.html