11.17学习内容

来源:互联网 发布:游戏场景设计软件 编辑:程序博客网 时间:2024/06/16 02:07

http://developer.51cto.com/art/201105/263219.htm

1.jdk7中新特性:

JDK7对Java语法有少量更新,重点是在易用性和便捷性的改进。

1.二进制字面量

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

Java代码

  1. byte nByte = (byte)0b0001;     
  2. short nShort = (short)0B0010;     
  3. int nInt = 0b0011;     
  4. long nLong = 0b0100L;   

2.数字字面量可以出现下划线

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

Java代码

  1. int a = 10_0000_0000;     
  2. long b = 0xffff_ffff_ffff_ffffl;     
  3. byte c = 0b0001_1000;   

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

1.数字的开头或者结尾

2.小数点的前后

3.‘F’或者‘f’的后缀

4.只能用数字的位置

Java代码

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

3.switch 语句可以用字符串了

这个功能千呼万唤,终于出来了

Java代码

  1. private static void switchString(String str){     
  2.         switch(str){     
  3.             case "one":     
  4.                 System.err.println("1");     
  5.                 break;     
  6.             case "two":     
  7.                 System.out.println("2");     
  8.                 break;     
  9.             default :     
  10.                 System.out.println("err");     
  11.         }     

4.泛型实例的创建可以通过类型推断来简化

以后你创建一个泛型实例,不需要再详细说明类型,只需用<>,编译器会自动帮你匹配

Java代码

  1. //例如      
  2. Map<string, list> myMap = new HashMap<string, list>();     
  3. //可以简化为     
  4. Map<string, list> myMap = new HashMap<>(); 

5.在可变参数方法中传递非具体化参数(Non-Reifiable Formal Parameters),改进编译警告和错误

有些参数类型,例如ArrayList 和 List,是非具体化的(non-reifiable).在编译阶段,编译器会擦除该类型信息。

Heap pollution 指一个变量被指向另外一个不是相同类型的变量。例如

Java代码

  1. List l = new ArrayList();     
  2.        List ls = l;       // unchecked warning     
  3.        l.add(0new Integer(42)); // another unchecked warning     
  4.        String s = ls.get(0);      // ClassCastException is thrown  

回到我们的主题,在jdk7中,当你定义下面的函数时

Java代码

  1. public static  void addToList (List listArg, T... elements) {     
  2.     for (T x : elements) {     
  3.       listArg.add(x);     
  4.     }     
  5.   }  

你会得到一个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代码

  1. static String readFirstLineFromFile(String path) throws IOException {     
  2.   try (BufferedReader br = new BufferedReader(new FileReader(path))) {     
  3.     return br.readLine();     
  4.   }     
  5. }  

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

Java代码

  1. try (     
  2.       java.util.zip.ZipFile zf = new java.util.zip.ZipFile(zipFileName);     
  3.       java.io.BufferedWriter writer = java.nio.file.Files.newBufferedWriter(outputFilePath, charset)     
  4.     ) {     
  5. }catch(…){     
  6. }finally{     
  7. }  

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

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

Java代码

  1. catch (IOException ex) {     
  2.      logger.log(ex);     
  3.      throw ex;     
  4. catch (SQLException ex) {     
  5.      logger.log(ex);     
  6.      throw ex;     
  7. }  

Jdk7允许捕获多个异常

Java代码

  1. catch (IOException|SQLException ex) {     
  2.     logger.log(ex);     
  3.     throw ex;     
  4. }  

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

Rethrow Exception更具包容性的类型检测

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

Java代码

  1. public void call() throws ReflectiveOperationException, IOException {     
  2.     try {     
  3.       callWithReflection(arg);     
  4.     } catch (final Exception e) {     
  5.       logger.trace("Exception in reflection", e);     
  6.       throw e;     
  7.     }     
  8. }  

参考资料

Jdk7官网 http://openjdk.java.net/projects/jdk7/



亲自卸载掉java6,装上7发现不能使用新语法,报错缺少配置pom.xml(第一次出现了),冉静就不行了,原因就不找了







jquery get请求

<!DOCTYPE html><html><head><meta charset="utf-8" /><script src="http://www.w3school.com.cn/jquery/jquery-1.11.1.min.js"></script><script>$(document).ready(function(){  $("button").click(function(){    $.get("/oo/test.txt",function(data,status){      alert("数据:" + data + "\n状态:" + status);    });  });});</script></head><body><button>向页面发送 HTTP GET 请求,然后获得返回的结果</button></body></html>
url如果不是本地路径,会无反应





0 0