zoukankan      html  css  js  c++  java
  • Windows和Linux 行尾符(EndOfLine)的区别

    转载用于收藏学习,原文链接:https://blog.csdn.net/timberwolf_2012/article/details/28687477

    不同操作系统,文本文件的行尾符是有区别的。

    1. 各系统关于行尾符(End-of-Line)的规定
      Unix每行结尾为" ",
      Windows系统每行结尾是“ ”,
      Mac OS在 OS X以前每行结尾是" ", 现在每行结尾是 " ".

    2. 概念区分

     


    3. 回车与换行来历


    在计算机还没有出现之前,有一种叫做电传打字机(Teletype Model 33)的玩意,每秒钟可以打10个字符。但是它有一个问题,就是打完一行换行的时候,要用去0.2秒,正好可以打两个字符。要是在这0.2秒里面,又有新的字符传过来,那么这个字符将丢失。
    于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做“回车”,告诉打字机把打印头定位在左边界;另一个叫做“换行”,告诉打字机把纸向下移一行。
    这就是“换行”和“回车”的来历,从它们的英语名字上也可以看出一二。
    后来,计算机发明了,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。


    结果是,
      Unix每行结尾为’ ‘, Windows系统每行结尾是“ ”, Mac系统每行结尾是' ',
    后果是,
      Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;
      Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。

    4. 编程相关
      在Windows系统中,文本文件以" "代表换行。
      用fputs等函数写换行符 ' '时,Windows会将 ' '隐式转换为" ",然后再写入到文件中。
      用fgets等函数读换行符 ' ' 的时候,Windows会将文件中的" "隐式转换为' ',然后再读到变量中。

    5. 实例分析
      生成一个包含换行( , 0x0A)和回车( , 0x0D)组合的文本
      $ echo -en '1 2 3' > temp

      十六进制方式查看文本:
      $ xxd temp




    Linux中查看文本:
      $ xxd -r temp
      $ vim temp



    Windows中查看文本:


    6. 不同平台间文本文件转换
    编辑器实现转换。
    NotePad++/Ultra Edit/Sublime Text2提供了转换功能。
    用Linux命令实现转换。
    Windows到Unix $ sed -e 's/.$//' mydos.txt > myunix.txt
    Unix到Windows $ sed -e 's/$/ /' myunix.txt > mydos.txt
    用Linux命令实现转换。
    $ unix2dos filename
    $ dos2unix filename
    ————————————————
    版权声明:本文为CSDN博主「czzshr」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/timberwolf_2012/article/details/28687477

  • 相关阅读:
    Hierarchy Query (Connect by) and ORA600 ([kkqcbydrv:1])
    The Steps to Create a New Oracle Database
    Change Schema Name (II)
    [转]The differences between V$UNDOSTAT and V$ROLLSTAT
    【Oracle Mgmt】Oracle Character Semantics (NLS_LENGTH_SEMANTICS) and etc...
    [Oracle Mgmt]About Oracle Password File
    Show parameter & Table Not exists
    RMAN Recovery Window and Redundancy Concept
    [PLSQL]Are you sure it will be definitely random? (DBMS_RANDOM.SEED)
    IOT, Secondary Index and Mapping Table
  • 原文地址:https://www.cnblogs.com/jiguang321/p/15029319.html
Copyright © 2011-2022 走看看