Java 1.7 语法新特性
2015-12-30 16:35
447 查看
1.自动资源管理
Java中某些资源是需要手动关闭的,如InputStream,Writes,Sockets,Sql classes等。这个新的语言特性允许try语句本身申请更多的资源,这些资源作用于try代码块,并自动关闭。
以前的写法:
现在的写法:
2.改进的通用实例创建类型推断
类型推断是一个特殊的烦恼,如下面的代码:
通过类型推断后变成:
注:这个<>被叫做diamond(钻石)运算符,Java 7后这个运算符从引用的声明中推断类型。
3.数字字面量下划线支持
很长的数字可读性不好,在Java 7中可以使用下划线分隔长int以及long了。如:int one_million = 1_000_000;
这样子还真看不惯。。。不过的确是可读性好了。
4.switch中使用string
以前在switch中只能使用基本类型如int、char、enum。现在可以使用string了
5.二进制字面量
由于继承C语言,Java代码在传统上迫使程序员只能使用十进制,八进制或十六进制来表示数(numbers)。
由于很少的域是以bit导向的,这种限制可能导致错误。你现在可以使用0b前缀创建二进制字面量:
int binary = 0b1001_1001;
现在,可以使用二进制字面量这种表示方式,并且使用非常简短的代码,可将二进制字符转换为数据类型,如在
byte或short。
6.简化可变参数方法调用
当参数为不可具体化的类型时,如List,编译器将产生警告,需要使用@SuppressWarnings(“unchecked”)注解声明;
Java7中使用@SafeVarargs注解抑制编译器警告。
Java中某些资源是需要手动关闭的,如InputStream,Writes,Sockets,Sql classes等。这个新的语言特性允许try语句本身申请更多的资源,这些资源作用于try代码块,并自动关闭。
以前的写法:
BufferedReader br = new BufferedReader(new FileReader(path)); try { br.readLine(); }catch(IOException e){ e.printStackTrace(); }finally { try { br.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
现在的写法:
try (BufferedReader br = new BufferedReader(new FileReader(path));) { br.readLine(); }
2.改进的通用实例创建类型推断
类型推断是一个特殊的烦恼,如下面的代码:
Map<String, List<String>> anagrams = new HashMap<String,List<String>>();
通过类型推断后变成:
Map<String, List<String>> anagrams = new HashMap<>();
注:这个<>被叫做diamond(钻石)运算符,Java 7后这个运算符从引用的声明中推断类型。
3.数字字面量下划线支持
很长的数字可读性不好,在Java 7中可以使用下划线分隔长int以及long了。如:int one_million = 1_000_000;
这样子还真看不惯。。。不过的确是可读性好了。
4.switch中使用string
以前在switch中只能使用基本类型如int、char、enum。现在可以使用string了
String sex= "男"; switch (sex) { case "男": System.out.println("先生"); break; case "女": System.out.println("女士"); break; default: System.out.println("女士"); }
5.二进制字面量
由于继承C语言,Java代码在传统上迫使程序员只能使用十进制,八进制或十六进制来表示数(numbers)。
由于很少的域是以bit导向的,这种限制可能导致错误。你现在可以使用0b前缀创建二进制字面量:
int binary = 0b1001_1001;
现在,可以使用二进制字面量这种表示方式,并且使用非常简短的代码,可将二进制字符转换为数据类型,如在
byte或short。
byte aByte = (byte)0b001; short aShort = (short)0b010;
6.简化可变参数方法调用
public int sum(int... args) { int result = 0; for (int value : args) { result += value; } return result; }
当参数为不可具体化的类型时,如List,编译器将产生警告,需要使用@SuppressWarnings(“unchecked”)注解声明;
Java7中使用@SafeVarargs注解抑制编译器警告。
@SafeVarargs public static <T> T useVarargs(T... args) { return args.length > 0 ? args[0] : null; } VarargsWarning.useVarargs(new ArrayList<String>());
相关文章推荐
- java集合:线性表
- eclipse重新设置workspace路径
- 关于不再使用的Java对象手工指null是否有意义
- java设计模式----责任链模式
- 可能是东半球最全的RxJava使用场景小结
- spring mvc 用ajaxSubmit 在iE8上传文件变下载的问题
- SpringMVC中使用DWR
- hbase数据迁移put方法java代码
- Java中的static关键字解析
- Spring学习笔记(十四):junit4的使用
- sikuli+java实例
- Java - wait()/notify()
- MyEclipse10的一些问题(git插件,jdk7)
- SpringMVC与iReport整合开发时的PDF中文显示处理
- Java中对象的深复制(深克隆)和浅复制(浅克隆)介绍
- Java基础之集合
- Java基础之集合
- Java基础之集合
- 初学Java语法(笔记)
- Java基础之集合