java 异常 之 实战篇(trows 和 try catch Dead Code)

简介:
一:throws  trycatch 差别

(1)比如。publicFileWriter(String fileName) throws IOException{}

我在mian中创建一个FileWrite对象
importjava.io.*;
publicclass ShengmingThrows {
     public static void main(String[] args){
         try{
         FileWriter fw=new FileWriter("k.txt");
         } catch(
FileNotFoundException ex){}
    }
}

(2) 还有一种处理方法:
importjava.io.*;
publicclass ShengmingThrows {
     public static void main(String[] args)throws IOException{
        //try{
         FileWriter fw=new FileWriter("k.txt");
       // }
       // catch(IOException e){}
    }
}
请解释一下两种操作的不同之处。throws仅仅是声明异常,异常并没有处理throws仅仅是对该类声明会抛出一个异常,但没有对异常进行捕获,让别的调用它的方法进行处理。

或者继续抛出,抛给上一层函数或类的成员函数。。

try catch是对可能出现异常的代码捕获异常并对其进行处理

throws仅仅是声明异常,异常并没有处理
当然。try和
catch也不是非要处理啊。
像代码,
try{
        FileWriter fw=new FileWriter("k.txt");
        }
        catch(IOException e){}   //
catch里也是空的,它也没有处理啊

二:抛出什么异常。如捕获多个异常

(1)完整代码例如以下

File file = new File("d:\\a.txt");// 这个不是read的不会抛异常的,仅仅有。有可能抛出对应的异常,才写catch的,否则多余的catch eclipse也会报错的
BufferedReader bf = new BufferedReader(new FileReader(file));//有可能抛异常
catch(ParseException ex){// Date d1 = df.parse(tmp_date + t1);是因为parse函数抛出的异常,所以编程中能够依据函数的提示来书写异常
			ex.printStackTrace();
			System.out.println("数据解析异常:" + ex);
			// log.warn("****" + ex);
		}
	public static void main(String[] args){
		DateFormat df = new SimpleDateFormat("yy-MM-dd HH:mm:ss");
		
		String t1 = "07:30:45";
		String t2 = "08:32:46";
		String tmp_date = "2014-04-01 ";
		try{
			File file = new File("d:\\a.txt");// 这个不是read的不会抛异常的。仅仅有,有可能抛出对应的异常,才写catch的。否则多余的catch eclipse也会报错的
			BufferedReader bf = new BufferedReader(new FileReader(file));
			Date d1 = df.parse(tmp_date + t1);
			Date d2 = df.parse(tmp_date + t2);
			//System.out.println("******" + d1.compareTo(d2));
			System.out.println(d1.getTime());
			System.out.println(d2.getTime());
			long diff = d2.getTime()-d1.getTime();
			long hour = diff/(1000*60*60);
			diff = diff%(1000*60*60);
			long minute = diff/(1000*60);
			diff = diff%(1000*60);
			long second = diff/1000;
			
			System.out.println("hour=" + hour + ", minute=" + minute + ", second=" + second);//2685000
			
		}catch(ParseException ex){// Date d1 = df.parse(tmp_date + t1)是因为parse函数抛出的异常,所以编程中能够依据函数的提示来书写异常
			ex.printStackTrace();
			System.out.println("数据解析异常:" + ex);
			// log.warn("****" + ex);
		}catch(NullPointerException ex){
			ex.printStackTrace();
			System.out.println("空指针异常:" + ex);
			// log.warn("****" + ex);
		}catch(IndexOutOfBoundsException ex){
			ex.printStackTrace();
			System.out.println("数组越界异常:" + ex);
			// log.warn("****" + ex);
		}catch(RuntimeException ex){
			ex.printStackTrace();
			System.out.println("执行时异常,NullPointerException IndexOutOfBoundsException 都是其子类" + ex);
			// log.warn("****" + ex);
		}
		catch(FileNotFoundException ex){
			ex.printStackTrace();
			System.out.println("文件找不到异常:" + ex);
			// log.warn("****" + ex);
		}catch(IOException ex){
			ex.printStackTrace();
			System.out.println("IO读取异常,是FileNotFoundException的父类" + ex);
			// log.warn("****" + ex);
		}catch(Exception ex){
			ex.printStackTrace();
			System.out.println("异常,上面各种异常的父类" + ex);
			// log.warn("****" + ex);
		}
	}

}

(2)总之,由于Exception这个是那几个异常的 父类或者基类。那几个异常都是他的子类,Exception放在最前面后面就没有机会了。其把全部的异常都捕获了。

三:初遇Dead Code

(1) Dead Code引起的原因

常常使用MyEclipseEclipse编辑器编写java代码的程序猿,可能常常遇到一个黄线警告提示:dead code;一般程序猿遇到这些问题都会置之不理,反正也不影响程序的

编译运行。对,这不是bug,仅仅是一个提示,对于一个有强迫症的程序猿来说,他非要代码一点问题都没有,包含黄线警告都要消灭掉。这里简单说下dead code 即死代

码、无作用的代码提示的原因和解决方法。

顾名思义,死代码,即你编写的那一行是无效代码,可有可无,说白了就是一行废话。这是你就要看一下这一行的处理逻辑是什么。可能是多余推断或者其它多余代码;比

如例如以下情况:

(2)情况一:无用的条件推断。就是你推断的这个条件永远为真

if (true& true) {

    System.out.println("execute ok");

  } else {

    System.out.println("executefail");

  }

 从else開始即为无作用。由于true&true在编绎时即知结果,所以else部分是没用的。编译器知道肯定不会运行的代码。

换成:

boolean a =true;

  boolean b = true;

  if (a & b) {

    System.out.println("execute ok");

  } else {

    System.out.println("executefail");

  }

则不会出现该问题。由于在编译时编译器不确定a & b是否恒成立。

(2)情况二:多余的推断,就是你推断的这个对象永远不为空;事实上类似于情况一

  TimeLineEventModel dataModel = new TimeLineEventModel();

if(dataModel !=null){

    运行一些操作....

}

这里的推断也是多余,由于你已经new了这个对象,那这个对象就不会为空。你刚刚new的对象。怎么会为空呢?

未完待续,可能还有其它一些情况的死代码。等到时候编码遇见了再进行补充吧!

眼下来看。deadcode提示一般出如今if或其它推断的条件上。








本文转自mfrbuaa博客园博客,原文链接:http://www.cnblogs.com/mfrbuaa/p/5170622.html,如需转载请自行联系原作者

相关文章
|
17天前
|
设计模式 安全 Java
Java并发编程实战:使用synchronized关键字实现线程安全
【4月更文挑战第6天】Java中的`synchronized`关键字用于处理多线程并发,确保共享资源的线程安全。它可以修饰方法或代码块,实现互斥访问。当用于方法时,锁定对象实例或类对象;用于代码块时,锁定指定对象。过度使用可能导致性能问题,应注意避免锁持有时间过长、死锁,并考虑使用`java.util.concurrent`包中的高级工具。正确理解和使用`synchronized`是编写线程安全程序的关键。
|
4天前
|
存储 Java 数据库连接
java DDD 领域驱动设计思想的概念与实战
【4月更文挑战第19天】在Java开发中,领域驱动设计(Domain-Driven Design, DDD) 是一种软件设计方法论,强调以领域模型为中心的软件开发。这种方法通过丰富的领域模型来捕捉业务领域的复杂性,并通过软件满足核心业务需求。领域驱动设计不仅是一种技术策略,而且还是一种与业务专家紧密合作的思维方式
21 2
|
14天前
|
Java API 开发者
Java 8新特性之函数式编程实战
【4月更文挑战第9天】本文将深入探讨Java 8的新特性之一——函数式编程,通过实例演示如何运用Lambda表达式、Stream API等技术,提高代码的简洁性和执行效率。
|
15天前
|
Java
Java中的异常类总结
Java中的异常类总结
|
25天前
|
存储 安全 Java
【Java技术专题】「Guava开发指南」手把手教你如何进行使用Guava工具箱进行开发系统实战指南(不可变集合篇)
【Java技术专题】「Guava开发指南」手把手教你如何进行使用Guava工具箱进行开发系统实战指南(不可变集合篇)
30 1
|
25天前
|
Java API Apache
【Java技术专题】「Guava开发指南」手把手教你如何进行使用Guava工具箱进行开发系统实战指南(基础编程篇)
【Java技术专题】「Guava开发指南」手把手教你如何进行使用Guava工具箱进行开发系统实战指南(基础编程篇)
43 0
|
27天前
|
算法 Java
Java8实战
Java8实战
40 1
|
1月前
|
SQL Java
java中的异常
java中的异常
10 1
|
1月前
|
Java 程序员 编译器
Java中异常
Java中异常
12 0
|
1月前
|
Java 程序员 编译器
Java中的异常
Java中的异常
9 0

热门文章

最新文章