Java中的异常对程序效率有无影响

上一篇 / 下一篇  2012-05-16 14:21:29 / 个人分类:Java

当异常没有发生时,没有影响。

r S6{O5s1[.a*Vs k0  其实从异常实现的角度来看,在throw语句处,跳转到异常的处理代码,不同的异常处理,应该类似C++中的虚函数表一样的数构结构(待考证)。51Testing软件测试网8r EM%hTc8?B

-JjRf*KY!~0  所以如果没有抛出异常,那和普通的代码完全一样。至于在抛出异常时要处理的开销和不使用异常,用返回码等来判断不同的错误,不仅代码复杂,而且也一样要有处理的开销。

+C-Y4cB}yq$]0

5xRzB1S{Et0  测试代码:51Testing软件测试网6\&gZ8s:j,xlv

  1. import java.util.Date;  

  2. {E-D8Xw@v1dD)o|0
  3. public class Test {  
  4.     long size = 1000000000L;  
  5.     public static void main(String[] args) {  
  6.         Test t = new Test();  
  7.         t.test1();  
  8.         t.test1();  
  9.         t.test1();  
  10.         t.test2();  
  11.         t.test2();  
  12.         t.test2();        
  13.         t.test1();  
  14.         t.test1();  
  15.         t.test1();  
  16.         t.test2();  
  17.         t.test2();  
  18.         t.test2();    
  19.           
  20.     }  
  21.       
  22.     long func1(long i) throws Exception{  
  23.         if(i == 0){  
  24.             throw new Exception("abc");  
  25.         }  
  26.         return i-1;  
  27.     }  
  28.       
  29.     long func2(long i){  
  30.         if(i == 0){  
  31.             return i + 1;  
  32.         }  
  33.         return i -1;  
  34.     }  
  35.       
  36.     void test1(){  
  37.         Date begin = new Date();  
  38.         long total = 0;  
  39.         for(long i = 1; i < size; ++i){  
  40.             try {  
  41.                 total += func1(i);  
  42.             } catch (Exception e) {  
  43.                 e.printStackTrace();  
  44.             }  
  45.         }  
  46.         Date end = new Date();  
  47.         System.out.println(total);  
  48.         System.out.println("test1 time:" + (end.getTime() - begin.getTime()));  
  49.           
  50.     }  
  51.       
  52.     void test2(){  
  53.         Date begin = new Date();  
  54.         long total = 0;  
  55.         for(long i = 1; i < size; ++i){  
  56.             total += func2(i);  
  57.         }  
  58.         Date end = new Date();  
  59.         System.out.println(total);  
  60.         System.out.println("test2 time:" + (end.getTime() - begin.getTime()));  
  61.     }  
  62. }

r*kxS#|aL9J0  总结:异常是个很有用的功能,在不抛出异常时,开销可以忽略不计。51Testing软件测试网7X2s|&UC

51Testing软件测试网U)g8sP)Vncyl1l

  在C++中也是如此。(TODO:测试C++代码中异常的效率)51Testing软件测试网uqH N&M i1~$yS;d


TAG:

 

评分:0

我来说两句

Open Toolbar