博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第十二章 通过异常处理错误
阅读量:4476 次
发布时间:2019-06-08

本文共 932 字,大约阅读时间需要 3 分钟。

1,system.out,与system.err的区别

   大多数操作系统都有三个标准文件描述符:标准输入,标准输出,标准出错。

      三个操作系统的文件描述符映射到编程语言的标准库中,往往加了一层包装,但是名字通常还是叫标准输入,标准输出,标准出错。
       在其它语言中的一般写法是:stdin,stdout,stderr(有的语言里大写,有的语言里小写)。对应Java中的System.in,System.out,System.err。
       在语言层面的实现三个文件描述符都是可以重定向的(只要你想)。但是一般而言,如果你在unix shell或windows command line中使用管道或重定向,则只是针对标准输入和输出。
       另外,标准输出和标准出错的一个区别是,标准输出往往是带缓存的,而标准出错没有缓存(默认设置,可以改)。所以如果你用标准出错打印出来的东西可以马上显示在屏幕,而标准输出打印出来的东西可能要再积累几个字符才能一起打印出来。如果你在应用中混用标准输出和标准出错就可能看到这个问题。
       总的来说,System.out用于正常的输出,也就是程序真正想输出的内容。而System.err用于出错信息的输出,也就是你本来不期待看到的东西。
        因此,System.err打出来的信息常常会跑到System.out信息的前面去。。。

比如,下面的程序,可能出现的结果不一样

System.err.println(new Date()+"err start");System.out.println("out");System.out.println(new Date()+"out end");
View Code

结果可能是

Sun Jul 02 08:31:02 CST 2015err start

out
Sun Jul 02 08:31:02 CST 2015out end

也可能是

out

Sun Jul 02 08:31:36 CST 2015out end
Sun Jul 02 08:31:36 CST 2015err start

2,

转载于:https://www.cnblogs.com/ningheshutong/p/7105072.html

你可能感兴趣的文章
通过例子学python(2.1)
查看>>
高效率场景-内存映射
查看>>
异步编程学习
查看>>
HDU-4639 Hehe 简单DP
查看>>
js严格模式总结
查看>>
bzoj 2238 Mst
查看>>
Python之多进程
查看>>
洛谷P2464 [SDOJ2008]郁闷的小J
查看>>
PHP 字符检测自定义函数
查看>>
【python练习笔记】神秘的王宫
查看>>
挖掘体会
查看>>
javascript:history对象
查看>>
Python基础——0前言
查看>>
机器学习三剑客之Numpy
查看>>
django路由转发
查看>>
HBase环境搭建随笔
查看>>
SAX vs. DOM (Event vs. Tree)
查看>>
堆排序原理及算法实现(最大堆)
查看>>
批量梯度下降法(Batch Gradient Descent)
查看>>
说说无线路由器后门的那些事儿(1)-D-Link篇
查看>>