jdk1.7的新特性

来源:互联网 发布:perl 数组查找字符串 编辑:程序博客网 时间:2024/06/08 00:06

jdk1.7的新特性: 

1.在switch语句中使用字符串

Java代码:String s = "test";   switch (s) {     case "test" :        System.out.println("test");    case "test1" :       System.out.println("test1");     break ;     default :       System.out.println("break");     break ;    }  


 2.泛型实例创建的类型推断

 jdk1.7之后,泛型实例的创建可以通过类型推断来简化  以后你创建一个泛型实例,不需要再详细说明类型,只需用<>,编译器会自动帮你匹配
 
List<String> list = new ArrayList<String>();可以写成List<String> list = new ArrayList<>();

 为了保持严谨的编码规范,一般还是写上类型

3.二进制类型

JDK7开始,终于可以用二进制来表示整数(byte,short,int和long)。使用二进制字面量的好处是,可以是代码更容易被理解。语法非常简单,只要在二进制数值前面加 0b或者0B

Java代码 
byte nByte = (byte)0b0001;  short nShort = (short)0B0010;  int nInt = 0b0011;  long nLong = 0b0100L;  


4.在数值类中使用下划线


对于一些比较大的数字,我们定义起来总是不方面,经常缺少或者增加位数。JDK7为我们提供了一种解决方案,下划线可以出现在数字字面量。


Java代码  
int a = 10_0000_0000;  long b = 0xffff_ffff_ffff_ffffl;  byte c = 0b0001_1000;  


注意:你只能将下划线置于数字之间,以下使用方法是错误的,


1.数字的开头或者结尾
2.小数点的前后
3.‘F’或者‘f’的后缀
4.只能用数字的位置

Java代码 
int err1 = _11,err2=11_;  float err3=3._4,err4=3_.4;  long err5=0x888_f;  



5.try-with-resources异常处理





jdk7提供了try-with-resources,可以自动关闭相关的资源



Java代码  
static String readFirstLineFromFile(String path) throws IOException {    try (BufferedReader br = new BufferedReader(new FileReader(path))) {      return br.readLine();    }  }  


try 语句块中还可以同时处理多个资源,可以跟普通的try语句一样catch异常,有finally语句块


 


Java代码 
try (        java.util.zip.ZipFile zf = new java.util.zip.ZipFile(zipFileName);        java.io.BufferedWriter writer = java.nio.file.Files.newBufferedWriter(outputFilePath, charset)      ) {  }catch(…){  }finally{  }  
 

jdk7提供了try-with-resources,可以自动关闭相关的资源(只要该资源实现了AutoCloseable接口,jdk7为绝大部分资源对象都实现了这个接口)


try 语句块中还可以同时处理多个资源,可以跟普通的try语句一样catch异常,有finally语句块






 6.捕获多个异常类型和重新抛出改良型检测异常



    很多时候,我们捕获了多个异常,却做了相同的事情,比如记日志,包装成新的异常,然后rethrow。这时,代码就不那么优雅了,例如


 
Java代码  
catch (IOException ex) {       logger.log(ex);       throw ex;  catch (SQLException ex) {       logger.log(ex);       throw ex;  }  

Java代码  
catch (IOException|SQLException ex) {      logger.log(ex);      throw ex;  }  


      注意,catch后面的异常参数是final的,不能重新再复制


      RethrowException更具包容性的类型检测

    当你重新抛出多个异常时,不再需要详细定义异常类型了,编译器已经知道你具体抛出的是哪个异常了。你只需在方法定义的时候声明需要抛出的异常即可



Java代码  
public void call() throws ReflectiveOperationException, IOException {      try {        callWithReflection(arg);      } catch (final Exception e) {        logger.trace("Exception in reflection", e);        throw e;      }  }  


Catch多个Exception,rethrow exception 改进了类型检测






7.实现了当使用可变方法做泛型的非具体化类型时编译器警告和报错


    有些参数类型,例如ArrayList<Number> 和 List<String>,是非具体化的(non-reifiable).在编译阶段,编译器会擦除该类型信息。
Heappollution 指一个变量被指向另外一个不是相同类型的变量。
例如

Java代码  
      
       List  list= new ArrayList<Number>();         List<String> ls = list;       // unchecked warning         l.add(0, new Integer(42)); // another unchecked warning         String s = ls.get(0);      // ClassCastException is thrown  


      在jdk7中,当你定义下面的函数时

Java代码  
public static <T> void addToList (List<T> listArg, T... elements) {      for (T x : elements) {        listArg.add(x);      }    }  

  你会得到一个warning

warning: [varargs] Possible heap pollution from parameterized vararg type 


    在jdk7之前,当你调用一个含有非具体化参数的可变参数方法,你必须自行保证不会发生“heappollution”。JDK7对此做了改进,在该方法被定义时久发出警告

要消除警告,有三种方式


1.加 annotation @SafeVarargs


2.加 annotation @SuppressWarnings({"unchecked", "varargs"})


3.使用编译器参数 –Xlint:varargs;






0 0
原创粉丝点击