回车和换行

作者: 阮一峰

日期: 2006年4月30日

今天,我总算搞清楚"回车"(carriage return)和"换行"(line feed)这两个概念的来历和区别了。

在计算机还没有出现之前,有一种叫做电传打字机(Teletype Model 33)的玩意,每秒钟可以打10个字符。但是它有一个问题,就是打完一行换行的时候,要用去0.2秒,正好可以打两个字符。要是在这0.2秒里面,又有新的字符传过来,那么这个字符将丢失。

于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做"回车",告诉打字机把打印头定位在左边界;另一个叫做"换行",告诉打字机把纸向下移一行。

这就是"换行"和"回车"的来历,从它们的英语名字上也可以看出一二。

后来,计算机发明了,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。

Unix系统里,每行结尾只有"<换行>",即"\n";Windows系统里面,每行结尾是"<回车><换行>",即"\r\n";Mac系统里,每行结尾是"<回车>"。一个直接后果是,Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;而Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。

(完)

珠峰培训

一灯学院

留言(23条)

非常感谢! 我在linux下面编程原来就是搞不明白为什么键盘一个回车键按下去, 结果程序居然得到两个字符: 回车和换行....

此文真解惑:) 但有一个问题
现象: windows下编辑的sql文本文件,经过ws_ftp传到unix下,可以直接执行, 而反之亦然, unix下生成的文本文件传到windows下也可以直接阅读,分行正确.
请教: 为何没有出现阮兄说的"^M"或"所有文字变成一行"呢?

这个应该不影响编程吧,编程好像除了特定的地方,一般来说空格都是忽略的,之所以要回车、换行只是为了方便阅读

我记得ws_ftp有选项可以自动对换行符做转换。

Windows下是 \r\n ,请修正,我在写程序的时候因为这个误导找了好久的bug

谢谢指出,已经改正了。

我没有认真核对,导致出现这样的重大错误,在此表示歉意。

原来\n \r\n是这么一回事,各系统都不统一,真伤脑筋呀

原来还有这段历史...

终于明白两者的区别了,原来一直区分不清。

解惑之作。

整理下:
【由来】
这2个概念最初来自打字机,引入2个特殊字符以填补从当前行尾到下行行首的操作时间空白,后来应用于计算机的行分隔符,不同OS处理不同:
Windows 回车换行\r\n
Unix 换行\n
Mac 回车\r

【原义】
回车 横向操作 carriage return CR,这个名字可能是指打印头像运作起来像奔跑的马车
换行 纵向操作 line feed LF,被吃掉一行

我的mac osx 10.9 行结尾和linux/unix一致,是“\n”,ascii 为10.
是说06年的时候 还是\r 么?
:)

解释的好透彻!

这个说法我有点儿补充::"回车"(carriage return)和"换行"(line feed) 是来源机械英文打字机的...电传打字机那个是后来的...
"车"指的是纸车,带着纸一起左右移动的模块。。。 当开始打第一个字之前,要把纸车拉到最右边,上紧弹簧。。随着打字, 弹簧把纸车拉回去..每当打完一行后,纸车就完全收回去了...所以叫回车.. 换行的概念就是 :: 打字机左边有个"把手 ",往下 扳动一下,纸会上移一行..

作者的blog非常解惑,少去了去翻大部头书的麻烦。

引用attilax的发言:

这个说法我有点儿补充::"回车"(carriage return)和"换行"(line feed)是来源机械英文打字机的...电传打字机那个是后来的...
"车"指的是纸车,带着纸一起左右移动的模块。。。 当开始打第一个字之前,要把纸车拉到最右边,上紧弹簧。。随着打字, 弹簧把纸车拉回去..每当打完一行后,纸车就完全收回去了...所以叫回车..换行的概念就是 :: 打字机左边有个"把手 ",往下 扳动一下,纸会上移一行..

必须给你点赞, 真正长姿势了

引用attilax的发言:

这个说法我有点儿补充::"回车"(carriage return)和"换行"(line feed)是来源机械英文打字机的...电传打字机那个是后来的...
"车"指的是纸车,带着纸一起左右移动的模块。。。 当开始打第一个字之前,要把纸车拉到最右边,上紧弹簧。。随着打字, 弹簧把纸车拉回去..每当打完一行后,纸车就完全收回去了...所以叫回车..换行的概念就是 :: 打字机左边有个"把手 ",往下 扳动一下,纸会上移一行..

大赞

感谢,另外,新年快乐!

有个疑问,按你说的,回车和换行是人为加在文档后面的,那么打印机看到'\r'的时候,要将打印头定位到最左边,假如这个过程需要 0.1s, 而在这 0.1s 中,'\n' 应该传过去了,由于没缓存,打印机看不到,那它是怎么工作的?

有个疑问,按你说的,回车和换行是人为加在文档后面的,那么打印机看到'\r'的时候,要将打印头定位到最左边,假如这个过程需要 0.1s, 而在这 0.1s 中,'\n' 应该传过去了,由于没缓存,打印机看不到,那它是怎么工作的?

引用attilax的发言:

这个说法我有点儿补充::"回车"(carriage return)和"换行"(line feed)是来源机械英文打字机的...电传打字机那个是后来的...
"车"指的是纸车,带着纸一起左右移动的模块。。。 当开始打第一个字之前,要把纸车拉到最右边,上紧弹簧。。随着打字, 弹簧把纸车拉回去..每当打完一行后,纸车就完全收回去了...所以叫回车..换行的概念就是 :: 打字机左边有个"把手 ",往下 扳动一下,纸会上移一行..

这个情节在电影《辛德勒名单》里面教一个女的学打字就可以看到,不知道是不是那个东西

解惑,文章10年依然经典

这个挺有意思的

原文:Mac系统里,每行结尾是""

这里过时了,现在的MAC OS X都是用换行\n,回车\r是以前老MAC系统的。

我要发表看法

«-必填

«-必填,不公开

«-我信任你,不会填写广告链接