他们间的区别其实是个回车换行的问题
先来段历史
回车”(Carriage Return)和“换行”(Line Feed)这两个概念的来历和区别。
符号 ASCII码 意义
\n 10 换行
\r 13 回车CR
在计算机还没有出现之前,有一种叫做电传打字机(Teletype Model 33,Linux/Unix下的tty概念也来自于此)的玩意,每秒钟可以打10个字符。但是它有一个问题,就是打完一行换行的时候,要用去0.2秒,正好可以打两个字符。要是在这0.2秒里面,又有新的字符传过来,那么这个字符将丢失。
于是,研制人员想了个办法解决这个问题,就是在每行后面加两个表示结束的字符。一个叫做“回车”,告诉打字机把打印头定位在左边界;另一个叫做“换行”,告诉打字机把纸向下移一行。这就是“换行”和“回车”的来历,从它们的英语名字上也可以看出一二。
后来,计算机发明了,这两个概念也就被般到了计算机上。那时,存储器很贵,一些科学家认为在每行结尾加两个字符太浪费了,加一个就可以。于是,就出现了分歧。
在Windows中:
'\r' 回车,回到当前行的行首,而不会换到下一行,如果接着输出的话,本行以前的内容会被逐一覆盖;
'\n' 换行,换到当前位置的下一行,而不会回到行首;
Unix系统里,每行结尾只有“<换行>”,即"\n";Windows系统里面,每行结尾是“<回车><换行>”,即“\r\n”;Mac系统里,每行结尾是“<回车>”,即"\r";。一个直接后果是,Unix/Mac系统下的文件在Windows里打开的话,所有文字会变成一行;而Windows里的文件在Unix/Mac下打开的话,在每行的结尾可能会多出一个^M符号。
例:
$ echo -en '12\n34\r56\n\r78\r\n' > tmp.txt
分别在Windws和Linux中查看此文件可知:
Linux中遇到换行符("\n")会进行回车+换行的操作,回车符反而只会作为控制字符("^M")显示,不发生回车的操作。而windows中要回车符+换行符("\r\n")才会回车+换行,缺少一个控制符或者顺序不对都不能正确的另起一行。
比如说现在有一个类:package com.shangpin.model;class Function { public void print(String s, Integer i) { System.out.println("print:String+int:"+s+i); } public void print(String s1, String s2) {
线程流,顾名思义就是在线程之间传输数据的流。主要用途自然就是用于线程之间通讯。线程流必须输入输出一起使用只使用一个会抛出 java.io.IOException: Pipe not connected而且也不能一个对应多个 只能一对一,一对多会抛出java.io.IOException: Already connected;例:import java.io.IOExceptio...
顺序表基本运算算法(seqlist.cpp)#include <stdio.h>#define MAXL 100 //最大长度typedef int KeyType; //定义关键字类型为inttypedef char InfoType;typedef struct{ KeyType key; //关键字项 InfoType data; //其他数据项,类型为InfoType} RecType; //查找元素的类型void swap(RecType x,RecT
问题如图:首先上传文件时,应该在ftp文件单独简历一个文件,引文ftp根目录的权限是 drwrx --rx--r root ftp 对于ftp的用户是无法进行写入的。如果你用chmod强行将ftp文件权限改为drwrx--wr--x root ftp 此时不用脚本登陆,直接在终端中登陆会提示因为chroot()的原因无法登陆。比如创建文件为upload,在ftp目录用ls -
四旋翼无人机基于stm32的设计与实现过程。
从action1直接跳转到action2,有两种方法: 1. 不保存前一个action的参数可以用这种方法: action2<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" "http://struts.apac
重要:文章说明:本文以在Proficy iFIX SCADA/HMI中,实现历史数据采集功能有两个步骤:用历史数据定义选择数据用历史数据采集启动(或者停止)历史数据采集SCADA应用开发流程示意图SCADA/HMI应用开发步骤示意图历史数据归档概览A. iFIX 数据归档iFIX 数据归档/历史数据采集有多种方法可以存储实时的 iFIX 数据,以便将来调用:Proficy Historian fo...
Tensorflow 多元线性回归实现的总结1,定义算法公式,也就是神经网络forward时的计算2,定义loss,选定优化器,并指定优化器优化loss3,迭代地对数据进行训练4,在测试集或验证集上对准确率进行评测1,定义算法公式,也就是神经网络forward时的计算from tensorflow.examples.tutorials.mnist import input_datai...
最近在看Mybatis的源码,刚好看到缓存这一块,Mybatis提供了一级缓存和二级缓存;一级缓存相对来说比较简单,功能比较齐全的是二级缓存,基本上满足了一个缓存该有的功能;当然如果拿来和专门的缓存框架如ehcache来对比可能稍有差距;本文我们将来整理一下实现一个本地缓存都应该需要考虑哪些东西。考虑点考虑点主要在数据用何种方式存储,能存储多少数据,多余的数据如何处理等几个点,下面我们来详细的介绍每个考虑点,以及该如何去实现;1.数据结构首要考虑的就是数据该如何存储,用什么数据结构存储,最简单的就直
在activiti的开发过程中,要用到查看流程图,咖啡兔
问题: 把n个球放到r个盒子里一共有多少种分法?这里要考虑的因素包括:球是否区分、盒子是否区分、盒中是否允许为空? 讨论:球可区分、盒可区分、允许空盒对每个球而言都可以选择放在任意一个盒子中,并且这样得到的结果不会与其他重合,因此有rn种选择球可区分、盒可区分、不允许空盒首先将n个球分成r个非空子集(共S(n, r)种),对于每个这样的划分,它
ubuntu 20.04LTS + gerrit + git + jenkins安装与部属前言 一、pandas是什么? 二、使用步骤 1.引入库 2.读入数据 总结目的最近想在局域网搭建一个软件版本管理、代码审查、及CI的开发环境,看了很多博客,内容比较分散,且失败了很多次,也走了不少弯路,现在把成功的步骤记录下来,以便于后期参考。一、pandas是什么?示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。二、使用步骤.