1.泛型(Generic)
C++通過模板技術可以指定集合的元素類型,而Java在1.5之前一直沒有相對應的功能。一個集合可以放任何類型的對象,相應地從集合裏面拿對象的時候我們也不得不對他們進行強制得類型轉換。猛虎引入了泛型,它允許指定集合裏元素的類型,這樣你可以得到強類型在編譯時刻進行類型檢查的好處。
Collection<string></string> c = new ArrayList(); c.add(new Date()); |
編譯器會給出一個錯誤:
add(java.lang.String) in java.util.Collection<java></java> cannot be applied to (java.util.Date) |
2.For-Each循環
For-Each循環得加入簡化了集合的遍歷。假設我們要遍歷一個集合對其中的元素進行一些處理。典型的代碼爲:
void processAll(Collection c){ for(Iterator i=c.iterator(); i.hasNext();){ MyClass myObject = (MyClass)i.next(); myObject.process(); } } |
使用For-Each循環,我們可以把代碼改寫成:
void processAll(Collection<myclass></myclass> c){ for (MyClass myObject :c) myObject.process(); } |
這段代碼要比上面清晰許多,並且避免了強制類型轉換。
3.自動裝包/拆包(Autoboxing/unboxing)
自動裝包/拆包大大方便了基本類型數據和它們包裝類地使用。
自動裝包:基本類型自動轉爲包裝類.(int >> Integer)
自動拆包:包裝類自動轉爲基本類型.(Integer >> int)
在JDK1.5之前,我們總是對集合不能存放基本類型而耿耿於懷,現在自動轉換機制解決了我們的問題。
int a = 3; Collection c = new ArrayList(); c.add(a);//自動轉換成Integer. Integer b = new Integer(2); c.add(b + 2); |
這裏Integer先自動轉換爲int進行加法運算,然後int再次轉換爲Integer.
4.枚舉(Enums)
JDK1.5加入了一個全新類型的“類”-枚舉類型。爲此JDK1.5引入了一個新關鍵字enmu. 我們可以這樣來定義一個枚舉類型。
public enum Color { Red, White, Blue } |
然後可以這樣來使用Color myColor = Color.Red.
枚舉類型還提供了兩個有用的靜態方法values()和valueOf(). 我們可以很方便地使用它們,例如
for (Color c : Color.values()) System.out.println(c); |
5.可變參數(Varargs)
可變參數使程序員可以聲明一個接受可變數目參數的方法。注意,可變參數必須是函數聲明中的最後一個參數。假設我們要寫一個簡單的方法打印一些對象,
util.write(obj1); util.write(obj1,obj2); util.write(obj1,obj2,obj3); … |
在JDK1.5之前,我們可以用重載來實現,但是這樣就需要寫很多的重載函數,顯得不是很有效。如果使用可變參數的話我們只需要一個函數就行了
public void write(Object... objs) { for (Object obj: objs) System.out.println(obj); } |
在引入可變參數以後,Java的反射包也更加方便使用了。對於c.getMethod("test", new Object[0]).invoke(c.newInstance(), new Object[0])),現在我們可以這樣寫了c.getMethod("test").invoke(c.newInstance()),這樣的代碼比原來清楚了很多。
6.靜態導入(Static Imports)
要使用用靜態成員(方法和變量)我們必須給出提供這個方法的類。使用靜態導入可以使被導入類的所有靜態變量和靜態方法在當前類直接可見,使用這些靜態成員無需再給出他們的類名。
import static java.lang.Math.*; ……. r = sin(PI * 2); //無需再寫r = Math.sin(Math.PI); |
不過,過度使用這個特性也會一定程度上降低代碼地可讀性。
數據的輸入Scanner
Scanner是SDK1.5新增的一個類,可是使用該類創建一個對象.
Scanner reader=new Scanner(System.in);
然後reader對象調用下列方法(函數),讀取用戶在命令行輸入的各種數據類型:
next.Byte(),nextDouble(),nextFloat,nextInt(),nextLine(),nextLong(),nextShot()
上述方法執行時都會造成堵塞,等待用戶在命令行輸入數據回車確認.例如,擁護在鍵盤輸入12.34,hasNextFloat()的值是true,而hasNextInt()的值是false. NextLine()等待用戶輸入一個文本行並且回車,該方法得到一個String類型的數據
import java.util;
public class Example
{
public static void main(String args[])
{
System.out.println(“請輸入若干個數,每輸入一個數用回車確認”);
Sytem.out.println(“最後輸入一個非數字結束輸入操作”);
Scanner reader=new Scanner(System.in);
double sum=0;
int m=0;
while(reader.hasNextDouble())
{
double x=reader.nextDouble();
m=m+1;
sum=sum+x;
}
System.out.print(“%d個數的和爲%f\n”,m,sum);
System.out.print(“%d個數的平均值是%f\n”,m,sum/m);
}
}