当前位置: 首页 > news >正文

做网站开发app沈阳最权威男科医院

做网站开发app,沈阳最权威男科医院,修改wordpress后台文字,网站跳出率因素异常对象的 printStackTrace() 方法用于打印异常的跟踪栈信息#xff0c;根据 printStackTrace() 方法的输出结果#xff0c;开发者可以找到异常的源头#xff0c;并跟踪到异常一路触发的过程。 看下面用于测试 printStackTrace 的例子程序。 class SelfException extends…异常对象的 printStackTrace() 方法用于打印异常的跟踪栈信息根据 printStackTrace() 方法的输出结果开发者可以找到异常的源头并跟踪到异常一路触发的过程。 看下面用于测试 printStackTrace 的例子程序。 class SelfException extends RuntimeException {SelfException() {}SelfException(String msg) {super(msg);} }public class PrintStackTraceTest {public static void main(String[] args) {firstMethod();}public static void firstMethod() {secondMethod();}public static void secondMethod() {thirdMethod();}public static void thirdMethod() {throw new SelfException(自定义异常信息);} }上面程序中 main 方法调用 firstMethodfirstMethod 调用 secondMethodsecondMethod 调用 thirdMethodthirdMethod 直接抛出一个 SelfException 异常。运行上面程序会看到如下所示的结果。 Exception in thread main Test.SelfException: 自定义异常信息at Test.PrintStackTraceTest.thirdMethod(PrintStackTraceTest.java:26)at Test.PrintStackTraceTest.secondMethod(PrintStackTraceTest.java:22)at Test.PrintStackTraceTest.firstMethod(PrintStackTraceTest.java:18)at Test.PrintStackTraceTest.main(PrintStackTraceTest.java:14)上面运行结果的第 2 行到第 5 行之间的内容是异常跟踪栈信息从打印的异常信息我们可以看出异常从 thirdMethod 方法开始触发传到 secondMethod 方法再传到 firstMethod 方法最后传到 main 方法在 main 方法终止这个过程就是 Java 的异常跟踪栈。 在面向对象的编程中大多数复杂操作都会被分解成一系列方法调用。这是因为实现更好的可重用性将每个可重用的代码单元定义成方法将复杂任务逐渐分解为更易管理的小型子任务。由于一个大的业务功能需要由多个对象来共同实现在最终编程模型中很多对象将通过一系列方法调用来实现通信执行任务。 所以面向对象的应用程序运行时经常会发生一系列方法调用从而形成“方法调用栈”异常的传播则相反只要异常没有被完全捕获包括异常没有被捕获或异常被处理后重新抛出了新异常异常从发生异常的方法逐渐向外传播首先传给该方法的调用者该方法调用者再次传给其调用者……直至最后传到 main 方法如果 main 方法依然没有处理该异常则 JVM 会中止该程序并打印异常的跟踪栈信息。 异常跟踪栈信息非常清晰它记录了应用程序中执行停止的各个点。 异常跟踪栈信息的第一行一般详细显示异常的类型和异常的详细消息接下来是所有异常的发生点各行显示被调用方法中执行的停止位置并标明类、类中的方法名、与故障点对应的文件的行。一行行地往下看跟踪栈总是最内部的被调用方法逐渐上传直到最外部业务操作的起点。 示范了多线程程序中发生异常的情形。 public class ThreadExceptionTest implements Runnable {public void run() {firstMethod();}public void firstMethod() {secondMethod();}public void secondMethod() {int a 5;int b 0;int c a / b;}public static void main(String[] args) {new Thread(new ThreadExceptionTest()).start();} }运行上面程序会看到如下运行结果。 Exception in thread Thread-0 java.lang.ArithmeticException: / by zeroat Test.ThreadExceptionTest.secondMethod(ThreadExceptionTest.java:14)at Test.ThreadExceptionTest.firstMethod(ThreadExceptionTest.java:8)at Test.ThreadExceptionTest.run(ThreadExceptionTest.java:4)at java.lang.Thread.run(Unknown Source)多线程异常的跟踪栈从发生异常的方法开始到线程的 run 方法结束。从上面的运行结果可以看出程序在 Thread 的 run 方法中出现了 ArithmeticException 异常这个异常的源头是 ThreadExcetpionTest 的 secondMethod 方法位于 ThreadExcetpionTest.java 文件的 14 行。这个异常传播到 Thread 类的 run 方法就会结束如果该异常没有得到处理将会导致该线程中止运行。 调用 Exception 的 printStackTrace() 方法就是打印该异常的跟踪栈信息也就会看到上面两个示例运行结果中的信息。当然如果方法调用的层次很深将会看到更加复杂的异常跟踪栈。 提示虽然 printStackTrace() 方法可以很方便地用于追踪异常的发生情况可以用它来调试程序但在最后发布的程序中应该避免使用它。应该对捕获的异常进行适当的处理而不是简单地将异常的跟踪栈信息打印出来。
http://wiki.neutronadmin.com/news/302527/

相关文章:

  • 建设手机银行网站谁专门做网站安全维护
  • 杭州做营销型网站网站建设与设计开题报告
  • 国外做家居类的网站南宁伯才网络
  • 做一个手机网站多少钱旅游景点网站建设规划书
  • 杭州企业建站程序免费国外代理网页
  • 漆包线 东莞网站建设自学编程网站
  • 免费淘宝网站建设天水做网站
  • 广东省住房城乡建设厅门户网站3d建模视频教学
  • 一般门户网站用r做简易的网站
  • 网站受众群体海兴县做网站价格
  • 做团购网站需要注册哪些商标怎么对自己的网页进行修改
  • html网站开发例子做电影网站用什么主机好
  • 双人网页游戏网站精准推广的渠道有哪些
  • 网站推广教程网络推广搜索引擎
  • 一分钟建设网站出口网站制作
  • 网站 框架图网站开发和网站制作的区别
  • 网站开发答辩难点哪个购物网站最便宜
  • wordpress网站慢app制作软件平台
  • 八冶建设集团有限公司网站本地云主机搭建wordpress
  • 做的网站加载太慢怎么办四子王旗建设局网站
  • 财务公司名称大全简单大气seo教程自学网
  • 找人做网站 源码被盗用wordpress各个页面名称标签
  • 网站扁平化设计理念富阳网站建设找哪家
  • 丽水网站域名注册服务公司微网站开发策划
  • 360网站托管WordPress用户中心激活版
  • 手机网站导航栏特效太原seo关键词排名优化
  • 天津宏宇网站建设淘宝网页设计模板html
  • 做网站需要哪个系统营销网络是什么意思
  • 网站开发 设计制作合同建设培训中心网站
  • 企业网站 asp源码h5制作开发价目表