假定我們現在想寫一個方法
Java采用的是類似的方法
作為一個例子
//: IceCream
// Returning arrays from methods
public class IceCream {
static String[] flav = {
};
static String[] flavorSet(int n) {
// Force it to be positive & within bounds:
n = Math
String[] results = new String[n];
int[] picks = new int[n];
for(int i =
picks[i] = -1;
for(int i = 0; i < picks.length; i++) {
retry:
while(true) {
int t =
(int)(Math.random() * flav.length);
for(int j = 0; j < i; j++)
if(picks[j] == t) continue retry;
picks[i] = t;
results[i] = flav[t];
break;
}
}
return results;
}
public static void main(String[] args) {
for(int i = 0; i < 20; i++) {
System.out.println(
"flavorSet(" + i + ") = ");
String[] fl = flavorSet(flav.length);
for(int j = 0; j < fl.length; j++)
System.out.println("\t" + fl[j]);
}
}
} ///:~
flavorSet()方法創建了一個名為results的String數組。Tw.wINGwIT.Com該數組的大小為n——具體數值取決於我們傳遞給方法的自變量。隨後,它從數組flav裡隨機挑選一些“香料”(Flavor),並將它們置入results裡,並最終返回results。返回數組與返回其他任何對象沒什麼區別——最終返回的都是一個句柄。至於數組到底是在flavorSet()裡創建的,還是在其他什麼地方創建的,這個問題並不重要,因為反正返回的僅是一個句柄。一旦我們的操作完成,垃圾收集器會自動關照數組的清除工作。而且只要我們需要數組,它就會乖乖地聽候調遣。
另一方面,注意當flavorSet()隨機挑選香料的時候,它需要保證以前出現過的一次隨機選擇不會再次出現。為達到這個目的,它使用了一個無限while循環,不斷地作出隨機選擇,直到發現未在picks數組裡出現過的一個元素為止(當然,也可以進行字串比較,檢查隨機選擇是否在results數組裡出現過,但字串比較的效率比較低)。若成功,就添加這個元素,並中斷循環(break),再查找下一個(i值會遞增)。但假若t是一個已在picks裡出現過的數組,就用標簽式的continue往回跳兩級,強制選擇一個新t。用一個調試程序可以很清楚地看到這個過程。
main()能顯示出20個完整的香料集合,所以我們看到flavorSet()每次都用一個隨機順序選擇香料。為體會這一點,最簡單的方法就是將輸出重導向進入一個文件,然後直接觀看這個文件的內容。
From:http://tw.wingwit.com/Article/program/Java/JSP/201311/19484.html