java 5 7_Java5、Java6、Java7的新特性

Java5:1、泛型 Generics:引用泛型之后,允許指定集合里元素的類型,免去了強制類型轉換,並且能在編譯時刻進行類型檢查的好處。Parameterized Type作為參數和返回值,Generic是vararg、annotation、enumeration、collection的基石。

A、類型安全

拋棄List、Map,使用List、Map給它們添加元素或者使用Iterator遍歷時,編譯期就可以給你檢查出類型錯誤

B、方法參數和返回值加上了Type

拋棄List、Map,使用List、Map

C、不需要類型轉換

List list=new ArrayList();

String str=list.get(i);

D、類型通配符“?”

假設一個打印List中元素的方法printList,我們希望任何類型T的List都可以被打印:

代碼:

public void printList(List> list,PrintStream out)throws IOException{

for(Iterator> i=list.iterator();i.hasNext();){

System.out.println(i.next.toString());

}

}

如果通配符?讓我們的參數類型過於廣泛,我們可以把List>、Iterator> 修改為

List Extends Number>、Iterator Extends Number>限制一下它。

2、枚舉類型 Enumeration:

3、自動裝箱拆箱(自動類型包裝和解包)autoboxing & unboxing:

簡單的說是類型自動轉換。

自動裝包:基本類型自動轉為包裝類(int ——Integer)

自動拆包:包裝類自動轉為基本類型(Integer——int)

4、可變參數varargs(varargs number of arguments)

參數類型相同時,把重載函數合並到一起了。

如:public void test(object... objs){

for(Object obj:objs){

System.out.println(obj);

}

}

5、Annotations 它是java中的metadata

A、Tiger中預定義的三種標准annotation

a 、Override

指出某個method覆蓋了superclass 的method當你要覆蓋的方法名拼寫錯時編譯不通過

b、Deprecated

指出某個method或element類型的使用是被阻止的,子類將不能覆蓋該方法

c、SupressWarnings

關閉class、method、field、variable 初始化的編譯期警告,比如:List沒有使用 Generic,則@SuppressWarnings("unchecked")去掉編譯期警告。

B、自定義annotation

public @interface Marked{}

C、meta-annotation

或者說annotation的annotation

四種標准的meta-annotation全部定義在java.lang.annotaion包中:a, Target指定所定義的annotation可以用在哪些程序單元上如果Target沒有指定,則表示該annotation可以使用在任意程序單元上代碼1. @Target({ElementType.ANNOTATION_TYPE,2.          ElementType.CONSTRUCTOR,3.          ElementType.FIELD,4.          ElementType.LOCAL_VARIABLE,5.          ElementType.METHOD,6.          ElementType.PACKAGE,7.          ElementType.PARAMETER,8.          ElementType.TYPE})9. public @interface TODO {}b, Retention指出Java編譯期如何對待annotationannotation可以被編譯期丟掉,或者保留在編譯過的class文件中在annotation被保留時,它也指定是否會在JVM加載class時讀取該annotation代碼1. @Retention(RetentionPolicy.SOURCE)  // Annotation會被編譯期丟棄2. public @interface TODO1 {}3. @Retention(RetentionPolicy.CLASS)   // Annotation保留在class文件中,但會被JVM忽略4. public @interface TODO2 {}5. @Retention(RetentionPolicy.RUNTIME) // Annotation保留在class文件中且會被JVM讀取6. public @interface TODO3 {}c, Documented指出被定義的annotation被視為所熟悉的程序單元的公開API之一被@Documented標注的annotation會在javadoc中顯示,這在annotation對它標注的元素被客戶端使用時有影響時起作用d, Inherited該meta-annotation應用於目標為class的annotation類型上,被此annotattion標注的class會自動繼承父類的annotationD, Annotation的反射我們發現java.lang.Class有許多與Annotation的反射相關的方法,如getAnnotations、isAnnotationpresent我們可以利用Annotation反射來做許多事情,比如自定義Annotation來做Model對象驗證代碼1. @Retention(RetentionPolicy.RUNTIME)2. @Target({ ElementType.FIELD, ElementType.METHOD })3. public @interface RejectEmpty {4.     /** hint title used in error message */5.     String value() default "";6. }7.8. @Retention(RetentionPolicy.RUNTIME)9. @Target( { ElementType.FIELD, ElementType.METHOD })10. public @interface AcceptInt {11.     int min() default Integer.MIN_VALUE;12.     int max() default Integer.MAX_VALUE;13.     String hint() default "";14. }使用@RejectEmpty和@AcceptInt標注我們的Model的field,然后利用反射來做Model驗證

6、新的迭代語句(for(int n:numbers))

7、靜態導入(import static )

8、新的格式化方法(java.util.Formatter)

formatter.format("Remaining account balance: $%.2f", balance);

9、新的線程模型和並發庫Thread Framework

HashMap的替代者ConcurrentHashMap和ArrayList的替代者CopyOnWriteArrayList在大並發量讀取時采用java.util.concurrent包里的一些類會讓大家滿意BlockingQueue、Callable、Executor、Semaphore...

Java6:

1、引入了一個支持腳本引擎的新框架

2、UI的增強

3、對WebService支持的增強(JAX-WS2.0和JAXB2.0)

4、一系列新的安全相關的增強

5、JDBC4.0

6、Compiler API

7、通用的Annotations支持

Java7:

1,switch中可以使用字串了

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.運用List tempList = new ArrayList<>(); 即泛型實例化類型自動推斷

3.語法上支持集合,而不一定是數組

final List piDigits = [ 1,2,3,4,5,8 ];

4.新增一些取環境信息的工具方法

File System.getJavaIoTempDir() // IO臨時文件夾

File System.getJavaHomeDir() // JRE的安裝目錄

File System.getUserHomeDir() // 當前用戶目錄

File System.getUserDir() // 啟動java進程時所在的目錄5

5.Boolean類型反轉,空指針安全,參與位運算

Boolean Booleans.negate(Boolean booleanObj)

True => False , False => True, Null => Null

boolean Booleans.and(boolean[] array)

boolean Booleans.or(boolean[] array)

boolean Booleans.xor(boolean[] array)

boolean Booleans.and(Boolean[] array)

boolean Booleans.or(Boolean[] array)

boolean Booleans.xor(Boolean[] array)

6.兩個char間的equals

boolean Character.equalsIgnoreCase(char ch1, char ch2)

7.安全的加減乘除

int Math.safeToInt(long value)

int Math.safeNegate(int value)

long Math.safeSubtract(long value1, int value2)

long Math.safeSubtract(long value1, long value2)

int Math.safeMultiply(int value1, int value2)

long Math.safeMultiply(long value1, int value2)

long Math.safeMultiply(long value1, long value2)

long Math.safeNegate(long value)

int Math.safeAdd(int value1, int value2)

long Math.safeAdd(long value1, int value2)

long Math.safeAdd(long value1, long value2)

int Math.safeSubtract(int value1, int value2)

8.map集合支持並發請求,且可以寫成 Map map = {name:"xxx",age:18};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值