- 浏览: 929100 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
itzhongyuan:
java Random类详解 -
david_je:
你好,我看到你在C里面回调JAVA里面的方法是在native里 ...
Android NDK开发(1)----- Java与C互相调用实例详解 -
fykyx521:
请求锁是在 oncreate 释放实在ondestroy?? ...
Android如何保持程序一直运行 -
aduo_vip:
不错,总结得好!
Android读取assets目录下的资源 -
f839903061:
给的网址很给力哦!
Android 4.0.1 源码下载,编译和运行
JDK7对Java语法有少量更新,重点是在易用性和便捷性的改进。
1.二进制字面量
JDK7开始,终于可以用二进制来表示整数(byte,short,int和long)。使用二进制字面量的好处是,可以是代码更容易被理解。语法非常简单,只要在二进制数值前面加 0b或者0B
Java代码
2.数字字面量可以出现下划线
对于一些比较大的数字,我们定义起来总是不方面,经常缺少或者增加位数。JDK7为我们提供了一种解决方案,下划线可以出现在数字字面量。
Java代码
注意:你只能将下划线置于数字之间,以下使用方法是错误的,
1.数字的开头或者结尾
2.小数点的前后
3.‘F’或者‘f’的后缀
4.只能用数字的位置
Java代码
int err1 = _11,err2=11_;
float err3=3._4,err4=3_.4;
long err5=0x888_f;
3.switch 语句可以用字符串了
这个功能千呼万唤,终于出来了
Java代码
4.泛型实例的创建可以通过类型推断来简化
以后你创建一个泛型实例,不需要再详细说明类型,只需用<>,编译器会自动帮你匹配
Java代码
5.在可变参数方法中传递非具体化参数(Non-Reifiable Formal Parameters),改进编译警告和错误
有些参数类型,例如ArrayList 和 List,是非具体化的(non-reifiable).在编译阶段,编译器会擦除该类型信息。
Heap pollution 指一个变量被指向另外一个不是相同类型的变量。例如
Java代码
回到我们的主题,在jdk7中,当你定义下面的函数时
Java代码
在jdk7之前,当你调用一个含有非具体化参数的可变参数方法,你必须自行保证不会发生“heap pollution”。这有一个问题,如果调用者对方法不熟悉,他根本无法判断。JDK7对此做了改进,在该方法被定义时久发出警告
要消除警告,可以有三种方式
1.加 annotation @SafeVarargs
2.加 annotation @SuppressWarnings({"unchecked", "varargs"})
3.使用编译器参数 –Xlint:varargs;
6.try-with-resources 语句
jdk7提供了try-with-resources,可以自动关闭相关的资源(只要该资源实现了AutoCloseable接口,jdk7为绝大部分资源对象都实现了这个接口)
Java代码
try 语句块中还可以同时处理多个资源,可以跟普通的try语句一样catch异常,有finally语句块
Java代码
7.Catch多个Exception,rethrow exception 改进了类型检测
很多时候,我们捕获了多个异常,却做了相同的事情,比如记日志,包装成新的异常,然后rethrow。这时,代码就不那么优雅了,例如
Java代码
Jdk7允许捕获多个异常
Java代码
注意,catch后面的异常参数是final的,不能重新再复制
Rethrow Exception更具包容性的类型检测
当你重新抛出多个异常时,不再需要详细定义异常类型了,编译器已经知道你具体抛出的是哪个异常了。你只需在方法定义的时候声明需要抛出的异常即可
Java代码
1,菱形语法(泛型实例化类型自动推断)
2,在目前版本中,不可具体化的泛型(任意类型)可变参数,在编译时,会在调用处产生警告,JDK7里将这个警告挪到了方法定义处。
变化前:
4,支持二进制语法和单位级别的数字表示方式
5,从语法层面上支持集合,不再是数组的专利。
6,JSR 292 动态类型语言支持
7,动态资源管理
在目前版本的java中,当你操作流时,一定会加try..finally以保证出现异常时,流能被正确关闭。
在JDK7里,你只需要将资源定义在try()里,Java7就会在readLine抛异常时,自动关闭资源。另外,资源类必须实现 Disposable<?> 接口。支持管理多个资源
1.二进制字面量
JDK7开始,终于可以用二进制来表示整数(byte,short,int和long)。使用二进制字面量的好处是,可以是代码更容易被理解。语法非常简单,只要在二进制数值前面加 0b或者0B
Java代码
byte nByte = (byte)0b0001; short nShort = (short)0B0010; int nInt = 0b0011; long nLong = 0b0100L;
2.数字字面量可以出现下划线
对于一些比较大的数字,我们定义起来总是不方面,经常缺少或者增加位数。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;
3.switch 语句可以用字符串了
这个功能千呼万唤,终于出来了
Java代码
private static void switchString(String str){ switch(str){ case "one": System.err.println("1"); break; case "two": System.out.println("2"); break; default : System.out.println("err"); } }
4.泛型实例的创建可以通过类型推断来简化
以后你创建一个泛型实例,不需要再详细说明类型,只需用<>,编译器会自动帮你匹配
Java代码
//例如 Map> myMap = new HashMap>(); //可以简化为 Map> myMap = new HashMap<>();
5.在可变参数方法中传递非具体化参数(Non-Reifiable Formal Parameters),改进编译警告和错误
有些参数类型,例如ArrayList 和 List,是非具体化的(non-reifiable).在编译阶段,编译器会擦除该类型信息。
Heap pollution 指一个变量被指向另外一个不是相同类型的变量。例如
Java代码
List l = new ArrayList(); List ls = l; // unchecked warning l.add(0, new Integer(42)); // another unchecked warning String s = ls.get(0); // ClassCastException is thrown
回到我们的主题,在jdk7中,当你定义下面的函数时
Java代码
public static void addToList (List listArg, T... elements) { for (T x : elements) { listArg.add(x); } } 你会得到一个warning warning: [varargs] Possible heap pollution from parameterized vararg type
在jdk7之前,当你调用一个含有非具体化参数的可变参数方法,你必须自行保证不会发生“heap pollution”。这有一个问题,如果调用者对方法不熟悉,他根本无法判断。JDK7对此做了改进,在该方法被定义时久发出警告
要消除警告,可以有三种方式
1.加 annotation @SafeVarargs
2.加 annotation @SuppressWarnings({"unchecked", "varargs"})
3.使用编译器参数 –Xlint:varargs;
6.try-with-resources 语句
jdk7提供了try-with-resources,可以自动关闭相关的资源(只要该资源实现了AutoCloseable接口,jdk7为绝大部分资源对象都实现了这个接口)
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{ }
7.Catch多个Exception,rethrow exception 改进了类型检测
很多时候,我们捕获了多个异常,却做了相同的事情,比如记日志,包装成新的异常,然后rethrow。这时,代码就不那么优雅了,例如
Java代码
catch (IOException ex) { logger.log(ex); throw ex; catch (SQLException ex) { logger.log(ex); throw ex; }
Jdk7允许捕获多个异常
Java代码
catch (IOException|SQLException ex) { logger.log(ex); throw ex; }
注意,catch后面的异常参数是final的,不能重新再复制
Rethrow Exception更具包容性的类型检测
当你重新抛出多个异常时,不再需要详细定义异常类型了,编译器已经知道你具体抛出的是哪个异常了。你只需在方法定义的时候声明需要抛出的异常即可
Java代码
public void call() throws ReflectiveOperationException, IOException { try { callWithReflection(arg); } catch (final Exception e) { logger.trace("Exception in reflection", e); throw e; } }
1,菱形语法(泛型实例化类型自动推断)
List<String> list = new ArrayList<>(); // <>这个真的很像菱形
2,在目前版本中,不可具体化的泛型(任意类型)可变参数,在编译时,会在调用处产生警告,JDK7里将这个警告挪到了方法定义处。
变化前:
static <T> List<T> asList(T... elements) { ... } static List<Callable<String>> stringFactories() { Callable<String> a, b, c; ... // 警告处 return asList(a, b, c); } static <T> List<T> asList(T... elements) { ... } static List<Callable<String>> stringFactories() { Callable<String> a, b, c; ... // 警告处 return asList(a, b, c); } 变化后: // 警告处 static <T> List<T> asList(T... elements) { ... } static List<Callable<String>> stringFactories() { Callable<String> a, b, c; ... return asList(a, b, c); } // 警告处 static <T> List<T> asList(T... elements) { ... } static List<Callable<String>> stringFactories() { Callable<String> a, b, c; ... return asList(a, b, c); } 3,switch现在可以支持字符串了 String s = ... switch(s) { case "quux": processQuux(s); //没有break,继续往下 case "foo": case "bar": processFooOrBar(s); break; case "baz": processBaz(s); //没有break,继续往下 default: processDefault(s); break; } String s = ... switch(s) { case "quux": processQuux(s); //没有break,继续往下 case "foo": case "bar": processFooOrBar(s); break; case "baz": processBaz(s); //没有break,继续往下 default: processDefault(s); break; }
4,支持二进制语法和单位级别的数字表示方式
// 8位byte byte aByte = (byte)0b00100001; // 16位short short aShort = (short)0b1010000101000101; // 32位int int anInt1 = 0b10100001010001011010000101000101; // 8位byte byte aByte = (byte)0b00100001; // 16位short short aShort = (short)0b1010000101000101; // 32位int int anInt1 = 0b10100001010001011010000101000101; 支持单位级别的数字,提高可读性 long underScores = 9_223_372_036_854_775_807L; // 每三位加一下划线,等同于 9,223,372,036,854,775,807 long underScores = 9_223_372_036_854_775_807L; // 每三位加一下划线,等同于 9,223,372,036,854,775,807
5,从语法层面上支持集合,不再是数组的专利。
final List<Integer> piDigits = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5, 9]; final Set<Integer> primes = { 2, 7, 31, 127, 8191, 131071, 524287 }; final Map<Integer, String> platonicSolids = { 4 : "tetrahedron", 6 : "cube", 8 : "octahedron", 12 : "dodecahedron", 20 : "icosahedron" }; final List<Integer> piDigits = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5, 9]; final Set<Integer> primes = { 2, 7, 31, 127, 8191, 131071, 524287 }; final Map<Integer, String> platonicSolids = { 4 : "tetrahedron", 6 : "cube", 8 : "octahedron", 12 : "dodecahedron", 20 : "icosahedron" };
6,JSR 292 动态类型语言支持
Dynamic x = (动态语言脚本); Object y = x.foo("ABC").bar(42).baz(); Dynamic x = (动态语言脚本); Object y = x.foo("ABC").bar(42).baz();
7,动态资源管理
在目前版本的java中,当你操作流时,一定会加try..finally以保证出现异常时,流能被正确关闭。
BufferedReader br = new BufferedReader(new FileReader(path)); try { return br.readLine(); } finally { br.close(); } BufferedReader br = new BufferedReader(new FileReader(path)); try { return br.readLine(); } finally { br.close(); }
在JDK7里,你只需要将资源定义在try()里,Java7就会在readLine抛异常时,自动关闭资源。另外,资源类必须实现 Disposable<?> 接口。支持管理多个资源
try (BufferedReader br = new BufferedReader(new FileReader(path)) { return br.readLine(); }
发表评论
-
cocos2dx中利用xcode 调用java中的函数
2013-07-29 11:36 25251. 先把cocos2dx根目录中的 /Users/zhaos ... -
Java中HashMap遍历的两种方式
2013-07-23 13:58 996转]Java中HashMap遍历的两种方式 原文地址: htt ... -
eclipse配置javah命令
2013-07-18 10:48 19931.找到javah命令所在的目录 我的为 /usr/bi ... -
Ubuntu安装JDK6和JDK5
2013-05-19 19:04 1006sudo apt-get install sun-java6- ... -
JNI详解001_c++
2013-05-09 14:57 817public class HelloWorld { p ... -
java_jni详解_04
2013-05-09 14:13 1123public class ObjectArrayTest{ ... -
jni docs
2013-05-09 12:18 884http://docs.oracle.com/javase/1 ... -
java_jni详解_03
2013-05-09 11:55 1034直接看代码 public class I ... -
java_jni详解_02
2013-05-09 11:19 1238直接看代码吧 public clas ... -
java_jni详解_01
2013-05-08 17:15 956java中的jni 例子HelloWorld 准备过程: 1 ... -
Unable to execute dex: Java heap space 解决方案
2012-10-31 16:01 1221整理一下,网上提供两种方法: 1、eclip ... -
Java编译错误“No enclosing instance of type
2012-06-15 16:14 1272Java编译错误“No enclosing instance ... -
打第三方jar包
2012-06-11 11:03 1147方法一:(工程没有引用外部jar包时,直接导出) 选中工程 ... -
常用的System.getProperty()
2012-05-20 10:24 989public class TestSystemproperty ... -
Java编程中尽可能要做到的一些地方
2012-04-07 14:56 9261. 尽量在合适的场合使 ... -
Java 7七大新功能预览
2012-03-15 15:57 1230Java 7已经完成的7大新功能: 1 对集合类的 ... -
在mac下安装jdk1.7
2012-03-15 12:54 21560最近呢,想玩玩jdk1.7, ... -
Java中反射机制详解
2011-09-27 14:53 943反射: 可以动态的获取指定类中的成员,以及建立类对象。 好 ... -
非常有用的20个Java程序片段
2011-09-26 17:19 8561. 字符串有整型的相互转换 ... -
java输出图片的像素值
2011-09-22 17:17 2605import java.awt.image.BufferedI ...
相关推荐
2. **JDK7新特性<二> 语法** JDK7引入了一些新的语法特性,比如自动资源管理(try-with-resources)、多catch语句和钻石操作符()。自动资源管理简化了资源关闭的代码,多catch语句允许在一个catch块中处理多种...
方法引用是JDK8的新特性之一,允许将方法作为参数传递给其他方法。例如: public static void main(String[] args) { List<String> list = Arrays.asList("Hello", "World"); list.forEach(System.out::println);...
jdk8新特性,百度云盘。jdk8新特性,百度云盘。jdk8新特性,百度云盘。
**JDK 7 新特性详解** Java Development Kit (JDK) 的第七个主要版本,即 JDK 7(也称为 Java SE 7),引入了一系列新特性,以提高开发者的效率、增强语言功能并优化性能。这次更新是基于 Project Coin 的概念,它...
**JDK7,全称Java Development Kit 7,是Java编程语言的一个重要版本,它引入了许多新特性,显著提升了开发效率和程序性能。这个doc中文文档详细解析了JDK7的关键改进,对于Java开发者来说是一份极具价值的参考资料...
JDK1.5新特性
jdk8新特性.md
JDK 7,作为Java开发工具包的一个重要版本,由甲骨文公司在2011年7月28日发布,带来了许多令人期待的新特性和改进,这些改变不仅提升了编程效率,也增强了代码的可读性和维护性。下面,我们将详细解析JDK 7中的几个...
Jdk8新特性例子,内容包含 接口默认方法, 函数引用, java.util.stream api 和java.time api map的新增方法等。例子采用记事本编写,下载者需自行下载jdk8安装并配置好环境,编译(javac)运行(java)
视频教程地址:http://www.gulixueyuan.com/course/56
JDK1.8引入了许多重要的新特性,极大地提升了Java编程的效率和性能。以下是这些特性的详细介绍: 1、**Lambda表达式**: Lambda表达式是JDK1.8的一个重大改进,它允许开发者以更简洁的方式传递代码块。在上述示例中...
本篇主要关注JDK 7和8两个重要版本的新特性。 首先,JDK 7,是Java发展历程中的一个重要里程碑,它在2011年发布,引入了多项显著的改进。其中最重要的特性之一是“Try-with-resources”语句,这使得资源管理变得...
总结来说,JDK 1.8引入的这些新特性极大地增强了Java语言的表达能力,为开发者提供了更加强大和灵活的工具,使得编写高效、简洁的代码变得可能。这些新特性也反映了函数式编程风格在Java平台中的重要性日益增强,为...
Java Development Kit (JDK) 6是Java编程语言的一个重要版本,它引入了许多新特性,极大地提升了开发效率和应用程序性能。以下将详细阐述JDK6的一些核心新特性: 1. **改进的编译器(Project Coin)** JDK 6中的...
jdk5、jdk6新特性系统介绍.chm 系统、全面 本人自己整理的资料
简介官方文档:Lambda Expressions (The Java Tutorials > Learning the Java Language > Cla
[浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part [浪曦][原创]JDK5.0新特性[风中叶老师主讲]共10 part
### JDK8十大新特性详解 #### 一、接口的默认方法 在JDK8之前,接口只能定义抽象方法,不允许有具体的实现。然而在JDK8中引入了一个重要的概念——**默认方法**(Default Methods)。这允许我们在接口中提供一个...