Java关于e.printStackTrace()介绍
public void printStackTrace()将此 throwable 及其追踪输出至标准错误流。此方法将此 Throwable 对象的堆栈跟踪输出至错误输出流,作为字段 System.err 的值。输出的第一行包含此对象的 toString() 方法的结果。剩余行表示以前由方法 fillInStackTrace() 记录的数据。此信息的格式取决于实现,但以下示例是最常见的:
java.lang.NullPointerException
at MyClass.mash(MyClass.java:9)
at MyClass.crunch(MyClass.java:6)
at MyClass.main(MyClass.java:3)
本示例通过运行以下程序生成:
class MyClass {
public static void main(String[] args) {
crunch(null);
}
static void crunch(int[] a) {
mash(a);
}
static void mash(int[] b) {
System.out.println(b[0]);
}
}
还有就是,
catch(Exception e){
e.printStackTrace() ;
}
当try语句中出现异常是时,会执行catch中的语句,java运行时系统会自动将catch括号中的Exception e 初始化,也就是实例化Exception类型的对象。e是此对象引用名称。然后e(引用)会自动调用Exception类中指定的方法,也就出现了e.printStackTrace() ;。
printStackTrace()方法的意思是:在命令行打印异常信息在程序中出错的位置及原因。(这是白话解释,比较容易理解)
关于System.out.println(e)与e.printStackTrace()
在抛出异常的情况下,有很多方法,System.out.println(e);这个方法打印出异常,并且输出在哪里出现的异常;e.printStackTrace()也是打印出异常,但是它还将显示出更深的调用信息。比如说:
A extends ---> B extends---> C
当在创建A的过程中出现问题了,我们抛出异常。<
System.out.println(e),除了标准异常外,只打印at A 然后再向外层层输出。
e.printStackTrace(),除了标准异常外,打印
at C
at B
at A
.......再向外层调查。
在向外层调查的情况下,都一样。最后都会回到com.sun.midp.main.Main.main
System.out.println();当发生异常时显示你自己设定的字符串信息;就比如下面的代码,try里面进行IO操作,你知道要抛出异常肯定也是IO异常,catch里面就写上特定的IOException,自己打印就行了
try{
//function
}
catch(IOException exc){
System.out.println("IOException");
}
e.printStackTrace();是打印异常的堆栈信息,指明错误原因,其实当发生异常时,通常要处理异常,这是编程的好习惯,所以e.printStackTrace()可以方便你调试程序!
最新文章
- AMD and CMD are dead之KMDjs在JS工程化的努力
- nginx 基本操作
- redis master配置了密码进行主从同步
- samba共享服务器搭建 亲手实验
- magento日常使用
- PHP-关于$_SERVER
- HTML标签使用特写
- 第六届蓝桥杯B组C++试题
- hdu1560 搜索
- Win7无线网络共享设置方法
- (一)phoneGap之环境搭建教程及其example分析
- 【设计模式系列】之OO面向对象设计七大原则
- 一种解决eclipse中安装maven出错的方法
- CIF、DCIF、D1分辨率是多少?
- Python——各类库的安装(持续更新)
- 解决爬虫中遇到的js加密问题之有道登录js逆向解析
- 微信公众号 chinaxdt 的 解压密码 mima
- JavaScript学习 - 基础(八) - DOM 节点 添加/删除/修改/属性值操作
- 学习go语言一篇就够了(持续更新)
- Source Insight 4.0常用设置