今天,我总算搞清楚"回车"(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符号。
(完)
c 说:
非常感谢! 我在linux下面编程原来就是搞不明白为什么键盘一个回车键按下去, 结果程序居然得到两个字符: 回车和换行....
2007年12月13日 04:19 | # | 引用
iammaimai 说:
此文真解惑:) 但有一个问题
现象: windows下编辑的sql文本文件,经过ws_ftp传到unix下,可以直接执行, 而反之亦然, unix下生成的文本文件传到windows下也可以直接阅读,分行正确.
请教: 为何没有出现阮兄说的"^M"或"所有文字变成一行"呢?
2008年6月27日 23:06 | # | 引用
joiho 说:
这个应该不影响编程吧,编程好像除了特定的地方,一般来说空格都是忽略的,之所以要回车、换行只是为了方便阅读
2008年12月 6日 16:25 | # | 引用
LF/CR 说:
我记得ws_ftp有选项可以自动对换行符做转换。
2008年12月 7日 05:17 | # | 引用
闲耘™ 说:
Windows下是 \r\n ,请修正,我在写程序的时候因为这个误导找了好久的bug
2009年12月24日 00:33 | # | 引用
Ruan YiFeng 说:
谢谢指出,已经改正了。
我没有认真核对,导致出现这样的重大错误,在此表示歉意。
2009年12月24日 15:53 | # | 引用
dee 说:
原来\n \r\n是这么一回事,各系统都不统一,真伤脑筋呀
2013年5月13日 08:04 | # | 引用
peach5460 说:
原来还有这段历史...
2013年7月26日 10:54 | # | 引用
twlkyao 说:
终于明白两者的区别了,原来一直区分不清。
2013年12月22日 22:48 | # | 引用
albert1205 说:
解惑之作。
整理下:
【由来】
这2个概念最初来自打字机,引入2个特殊字符以填补从当前行尾到下行行首的操作时间空白,后来应用于计算机的行分隔符,不同OS处理不同:
Windows 回车换行\r\n
Unix 换行\n
Mac 回车\r
【原义】
回车 横向操作 carriage return CR,这个名字可能是指打印头像运作起来像奔跑的马车
换行 纵向操作 line feed LF,被吃掉一行
2014年2月17日 18:09 | # | 引用
tanglei 说:
我的mac osx 10.9 行结尾和linux/unix一致,是“\n”,ascii 为10.
是说06年的时候 还是\r 么?
:)
2014年7月 5日 23:33 | # | 引用
新一 说:
解释的好透彻!
2014年7月28日 20:50 | # | 引用
attilax 说:
这个说法我有点儿补充::"回车"(carriage return)和"换行"(line feed) 是来源机械英文打字机的...电传打字机那个是后来的...
"车"指的是纸车,带着纸一起左右移动的模块。。。 当开始打第一个字之前,要把纸车拉到最右边,上紧弹簧。。随着打字, 弹簧把纸车拉回去..每当打完一行后,纸车就完全收回去了...所以叫回车.. 换行的概念就是 :: 打字机左边有个"把手 ",往下 扳动一下,纸会上移一行..
2014年8月12日 16:59 | # | 引用
ayeli 说:
作者的blog非常解惑,少去了去翻大部头书的麻烦。
2014年9月15日 12:41 | # | 引用
路人甲 说:
必须给你点赞, 真正长姿势了
2015年4月15日 10:25 | # | 引用
linchen 说:
大赞
2015年11月21日 23:47 | # | 引用
GainSurier 说:
感谢,另外,新年快乐!
2016年1月 5日 18:49 | # | 引用
matrix 说:
有个疑问,按你说的,回车和换行是人为加在文档后面的,那么打印机看到'\r'的时候,要将打印头定位到最左边,假如这个过程需要 0.1s, 而在这 0.1s 中,'\n' 应该传过去了,由于没缓存,打印机看不到,那它是怎么工作的?
2016年4月26日 19:13 | # | 引用
matrix 说:
有个疑问,按你说的,回车和换行是人为加在文档后面的,那么打印机看到'\r'的时候,要将打印头定位到最左边,假如这个过程需要 0.1s, 而在这 0.1s 中,'\n' 应该传过去了,由于没缓存,打印机看不到,那它是怎么工作的?
2016年4月26日 19:15 | # | 引用
matt 说:
这个情节在电影《辛德勒名单》里面教一个女的学打字就可以看到,不知道是不是那个东西
2016年5月13日 13:16 | # | 引用
kkco 说:
解惑,文章10年依然经典
2016年5月17日 10:51 | # | 引用
元迎探惜 说:
这个挺有意思的
2016年6月29日 14:58 | # | 引用
batsing 说:
原文:Mac系统里,每行结尾是""
这里过时了,现在的MAC OS X都是用换行\n,回车\r是以前老MAC系统的。
2016年10月26日 10:52 | # | 引用
trying 说:
谢谢阮老师,从一接触计算机就看到您的各种文章,真是精辟,笔记本中一直记得您的博客地址,却一直未仔细阅读过,从今天开始准备把您的blog过一遍了,好好学习一下您分享的心得和知识,谢谢
2017年6月27日 10:58 | # | 引用
江山未 说:
同上,从头过blog的留个脚印。
2018年4月 4日 14:24 | # | 引用
渦笑 说:
有点疑惑安卓和Unix,Windows,Mac的关系,安卓是指手机系统吗?那么Mac的手机系统也和电脑系统一样吗?安卓系统又是怎样的呢?
2018年8月 3日 11:36 | # | 引用
ciciywg 说:
苹果操作系统要分为macOS和the classic Mac OS,前者跟linux一样了,都是0x0A(\n);后者才是0x0D(\r).
2018年8月27日 12:28 | # | 引用
王路 说:
为什么windows打开unxi mac文件会变成一行。。
2018年10月 8日 08:20 | # | 引用
不笑了 说:
老哥 我终于找到你了
这个回答的原作者
你的答案帮助了我
非常感谢
2019年4月 4日 14:48 | # | 引用
BrocadeShaw 说:
阮老师是我们的神!~!
2020年8月25日 20:19 | # | 引用
李星晨 说:
大神就是大神,语言干练,内容通透。
2021年8月26日 10:31 | # | 引用
狐篱 说:
学到了学到了,感觉一直学习框架语言对计算机的理解还是太浅薄了,接下来把大神的博客按照分类好好刷一刷
2023年2月 3日 11:03 | # | 引用