java 又一次抛出异常 相关处理结果演示样例代码

package org.rui.ExceptionTest;
/**
* 又一次抛出异常
*
在某些情况下,我们想又一次掷出刚才产生过的违例,特别是在用Exception 捕获全部可能的违例时。因为我
们已拥有当前违例的句柄,所以仅仅需简单地又一次掷出那个句柄就可以。以下是一个样例:
catch(Exception e) {
System.out.println("一个违例已经产生");
throw e;
}
又一次“掷”出一个违例导致违例进入更高一级环境的违例控制器中。 用于同一个try 块的不论什么更进一步的
catch 从句仍然会被忽略。 此外,与违例对象有关的全部东西都会得到保留。所以用于捕获特定违例类型的
更高一级的控制器能够从那个对象里提取出全部信息。
若仅仅是简单地又一次掷出当前违例,我们打印出来的、与printStackTrace()内的那个违例有关的信息会与违
例的起源地相应。而不是与又一次掷出它的地点相应。若想安装新的堆栈跟踪信息,可调用
fillInStackTrace(),它会返回一个特殊的违例对象。这个违例的创建步骤例如以下:将当前堆栈的信息填充到
原来的违例对象里。以下列出它的形式:
* @author lenovo
*
*/
public class Rethrowing {
public static void f() throws Exception
{
System.out.println("f() 方法运行");
throw new Exception("thrown form f()");
} public static void g() throws Exception
{
try {
f();
} catch (Exception e) {
System.out.println("inside g() ,e...");
e.printStackTrace(System.out);
throw e;//把补获的异常 又一次抛出异常
}
} public static void main(String[] args)
{
try {
g();
} catch (Exception e) {
System.out.println("main 处理异常 ");
e.printStackTrace(System.out);
} } }
/**
f() 方法运行
inside g() ,e...
java.lang.Exception: thrown form f()
at org.rui.ExceptionTest.Rethrowing.f(Rethrowing.java:7)
at org.rui.ExceptionTest.Rethrowing.g(Rethrowing.java:13)
at org.rui.ExceptionTest.Rethrowing.main(Rethrowing.java:25)
main 处理异常
java.lang.Exception: thrown form f()
at org.rui.ExceptionTest.Rethrowing.f(Rethrowing.java:7)
at org.rui.ExceptionTest.Rethrowing.g(Rethrowing.java:13)
at org.rui.ExceptionTest.Rethrowing.main(Rethrowing.java:25)
*/
package org.rui.ExceptionTest;

/**
* 可能在捕获异常之后抛出还有一种异常。 有关原来的异常发生点的信息会丢失。
* 剩下的是与新的抛出点有关的信息
* @author lenovo
*
*/ //自己定义异常
class OneException extends Exception
{
OneException(String s){ super(s);}
}
class TwoException extends Exception
{
TwoException(String s){ super(s);}
} ////////
public class RethrowNew {
public static void f() throws OneException
{
System.out.println("运行f方法 f()");
throw new OneException("thrown from f()");//
} public static void main(String[] args)
{ try {
try {
f();
} catch(OneException e)
{
System.out.println("内部异常处理, e.printStackTrace()");
e.printStackTrace();
throw new TwoException("抛出异常 inner try");
} } catch (TwoException e) {
System.out.println("outer try ---外部的异常处理");
e.printStackTrace(System.out);
}
}
}
/**
* 最后那个异常仅知道自已来自main 而对f()一无所知
*
output:
运行f方法 f()
内部异常处理, e.printStackTrace()
org.rui.ExceptionTest.OneException: thrown from f()
at org.rui.ExceptionTest.RethrowNew.f(RethrowNew.java:18)
at org.rui.ExceptionTest.RethrowNew.main(RethrowNew.java:26)
outer try ---外部的异常处理
org.rui.ExceptionTest.TwoException: 抛出异常 inner try
at org.rui.ExceptionTest.RethrowNew.main(RethrowNew.java:31) */ ///:~
package org.rui.ExceptionTest;

import java.util.Date;

/**
* 字符串格式化 演示样例
*
* 当中float类型与double类型的数据,对于String.format()方法来说,全表示为浮点数,可使用的格式化參数如:
String.format("%a, %e, %f, %g",floatType,floatType,floatType,floatType);
当中
%a 表示用十六进制表示
%e 表示用科学记数法表示
%f 表示用普通的10进制方式表示
%g 表示依据实际的类型的值的大小,或採用%e的方式,或採用%f的方式 对于日期类型的:
如:
String dataStr = String.format("%1$tm-%1$te-%1$tY",dateType);
当中1$表示假设參数中有多个dateType那么取哪个dateType中的值,
t表示日期或时间格式,
m表示月,e表示日,Y表示年.
*/
public class StringFormatTest { public static void main(String[] args) {
float floatType=1000.00f;
double doubleTyep=11111111111111111.00d;
Date dateType = new Date();
String floatStr = String.format("%a, %e, %f, %g",floatType,floatType,floatType,floatType);
String doubleStr = String.format("%a, %e, %f, %g",doubleTyep,doubleTyep,doubleTyep,doubleTyep);
String dataStr = String.format("%1$tm-%1$te-%1$tY",dateType);
System.out.println(floatStr);
System.out.println(doubleStr);
System.out.println(dataStr);
} } /** output:
0x1.f4p9, 1.000000e+03, 1000.000000, 1000.00
0x1.3bcbf936b38e4p53, 1.111111e+16, 11111111111111112.000000, 1.11111e+16
06-26-2014
*/

java 又一次抛出异常 相关处理结果演示样例代码的更多相关文章

  1. java文件夹相关操作 演示样例代码

    java文件夹相关操作 演示样例代码 package org.rui.io; import java.io.File; import java.io.FilenameFilter; import ja ...

  2. java I/O进程控制,重定向 演示样例代码

    java I/O进程控制,重定向 演示样例代码 package org.rui.io.util; import java.io.*; /** * 标准I/O重定向 */ public class Re ...

  3. java 线程、线程池基本应用演示样例代码回想

    java 线程.线程池基本应用演示样例代码回想 package org.rui.thread; /** * 定义任务 * * @author lenovo * */ public class Lift ...

  4. 展示C代码覆盖率的gcovr工具简单介绍及相关命令使用演示样例

    (本人正在參加2015博客之星评选,诚邀你来投票,谢谢:username=zhouzxi">http://vote.blog.csdn.net/blogstar2015/candida ...

  5. Java 18 新增@snipppet标签,注释中写样例代码更舒适了!

    在这次的Java 18中,新增了一个@snipppet标签,主要用于JavaDoc中需要放示例代码的场景.其实在Java 18之前,已经有一个@code标签,可以用于在JavaDoc中编写小段的代码内 ...

  6. java 状态模式 解说演示样例代码

    package org.rui.pattern; import junit.framework.*; /** * 为了使同一个方法调用能够产生不同的行为,State 模式在代理(surrogate)的 ...

  7. Java连接redis的使用演示样例

    Java连接redis的使用演示样例 Redis是开源的key-value存储工具,redis通经常使用来存储结构化的数据,由于redis的key能够包括String.hash.listset和sor ...

  8. ArcSDE SDK For Java二次开发介绍、演示样例

    在一个工作中,遇到了须要java后台来查询ArcGIS 中用到的Oracle数据库空间数据,因为对ArcGIS空间数据首次接触,仅仅知道Oracle能够使用ST_GEOMETRY字段存储,例如以下图 ...

  9. HTTP基本认证(Basic Authentication)的JAVA演示样例

    大家在登录站点的时候.大部分时候是通过一个表单提交登录信息.可是有时候浏览器会弹出一个登录验证的对话框.例如以下图,这就是使用HTTP基本认证.以下来看看一看这个认证的工作过程:第一步:  clien ...

随机推荐

  1. 俄罗斯水手 [C#] 对List<T>取交集、连集及差集

    ※本文使用int為例,若為使用自訂之DataModel,需實作IEquatable<T>介面才能使用 1.  取交集 (A和B都有) List A : { 1 , 2 , 3 , 5 , ...

  2. json字符串和dict互转

    json字符串和dict互转 import json str = '{"params":[{"id":222,"offset":0},{&q ...

  3. Cognos开发自定义排序规则的报表和自定义排名报表

    场景:有一个简单的销售数据分析,可以按照日期,按照商品类型来分析订单笔数和订单金额. 目的:用户可以自定义查看按照不同指标排序的数据,用户可以查看按照不同指标排名的前N名数据 一:功能及效果展示 效果 ...

  4. 微信公众号开发之如何使用JSSDK

    微信开发交流群:148540125 欢迎留言.转发.打赏 系列文章参考地址 极速开发微信公众号 项目源码参考地址 点我点我--欢迎Start 查看公众号是否有使用JSSDK的权限 服务号.订阅号可以通 ...

  5. C#.NET常见问题(FAQ)-程序如何把窗体文件从从一个项目中复制到另一个项目

    一个窗体有三个文件,全部拷贝到新的项目中   在新的项目中点击显示所有文件,然后右击导入的文件,点击包括在项目中,会自动修改颜色(此时还没有被识别为窗体)   重启这个项目,三个文件已经被识别出来了 ...

  6. Mockito: InvalidUseOfMatchersException

    异常报错信息: org.mockito.exceptions.misusing.InvalidUseOfMatchersException: Invalid use of argument match ...

  7. Nginx的负载均衡的几种方式

    Nginx的负载均衡的那点事 本节就聊聊采用Nginx负载均衡之后碰到的问题: Session问题 文件上传下载 通常解决服务器负载问题,都会通过多服务器分载来解决.常见的解决方案有: 网站入口通过分 ...

  8. java线程(上)Thread和Runnable的区别

    首先讲一下进程和线程的区别: 进程:每个进程都有独立的代码和数据空间(进程上下文),进程间的切换会有较大的开销,一个进程包含1--n个线程. 线程:同一类线程共享代码和数据空间,每个线程有独立的运行栈 ...

  9. MySQL Event计划任务刷慢日志

    前言 最近在尝试一个日志系统graylog来收集mysql的慢查询日志提,供后续的分析.监控和报警等.测试步骤已经到日志已成功收集到graylog,测试时需要刷一些慢查询日志出来.为了刷比较多的日志和 ...

  10. EXCEPTION-SQL语句

      CreateTime--2017年1月12日14:37:52Author:Marydon 声明:异常类文章主要是记录了我遇到的异常信息及解决方案,解决方案大部分都是百度解决的,(这里只是针对我遇到 ...