2016年java數組操作方法大全
使用java數組,必須經過兩個步驟,聲明數組和分配內存給該數組,那麼java怎麼分配內存給數組呢?數組的操作方法又有哪些呢?下面是yjbys精心整理的Java數組操作的10大方法,大部分代碼都來自Stack Overflow。希望對大家學習有所幫助!
定義一個Java數組
String[] aArray = new String[5];
String[] bArray = {"a","b","c", "d", "e"};
String[] cArray = new String[]{"a","b","c","d","e"};
第一種是定義了一個數組,並且指定了數組的長度,我們這裏稱它為動態定義。
第二種和第三種在分配內存空間的同時還初始化了值。
1、打印Java數組中的元素
int[] intArray = { 1, 2, 3, 4, 5 };
String intArrayString = ring(intArray);
// print directly will print reference value
tln(intArray);
// [I@7150bd4d
tln(intArrayString);
// [1, 2, 3, 4, 5]
這裏的重點是説明了Java中數組的引用和值得區別,第三行直接打印intArray,輸出的是亂碼,因為intArray僅僅是一個地址引用。第4行輸出的則是真正的.數組值,因為它經過了ring()的轉化。對Java初學者來説,引用和值仍需重視。
2、從Array中創建ArrayList
String[] stringArray = { "a", "b", "c", "d", "e" };
ArrayList arrayList = new ArrayList(st(stringArray));
tln(arrayList);
// [a, b, c, d, e]
為什麼要將Array轉換成ArrayList呢?可能是因為ArrayList是動態鏈表,我們可以更方便地對ArrayList進行增刪改,我們並不需要循環Array將每一個元素加入到ArrayList中,用以上的代碼即可簡單實現轉換。
3、檢查數組中是否包含某一個值
String[] stringArray = { "a", "b", "c", "d", "e" };
boolean b = st(stringArray)ains("a");
tln(b);
// true
先使用st()將Array轉換成List,這樣就可以用動態鏈表的contains函數來判斷元素是否包含在鏈表中。
4、連接兩個數組
int[] intArray = { 1, 2, 3, 4, 5 };
int[] intArray2 = { 6, 7, 8, 9, 10 };
// Apache Commons Lang library
int[] combinedIntArray = ll(intArray, intArray2);
ArrayUtils是Apache提供的數組處理類庫,其addAll方法可以很方便地將兩個數組連接成一個數組。
5、聲明一個數組內鏈
method(new String[]{"a", "b", "c", "d", "e"});
6、將數組中的元素以字符串的形式輸出
// containing the provided list of elements
// Apache common lang
String j = (new String[] { "a", "b", "c" }, ", ");
tln(j);
// a, b, c
同樣利用StringUtils中的join方法,可以將數組中的元素以一個字符串的形式輸出。
7、將Array轉化成Set集合
Set set = new HashSet(st(stringArray));
tln(set);
//[d, e, b, c, a]
在Java中使用Set,可以方便地將需要的類型以集合類型保存在一個變量中,主要應用在顯示列表。同樣可以先將Array轉換成List,然後再將List轉換成Set。
8、數組翻轉
int[] intArray = { 1, 2, 3, 4, 5 };
rse(intArray);
tln(ring(intArray));
//[5, 4, 3, 2, 1]
依然用到了萬能的ArrayUtils。
9、從數組中移除一個元素
while(!game_over)
{
for each possible move:
count_no_of_merges_for_2-tiles and 4-tiles
choose the move with large number of merges
}
再補充一個:將一個int值轉化成byte數組
byte[] bytes = cate(4)nt(8)y();
for (byte t : bytes) {
at("0x%x ", t);
}
-
二級Java試題精選(附答案)
1、結構化程序設計主要強調的是______。A、程序的規模B、程序的易讀性C、程序的執行效率D、程序的可移植性結構化程序設計主要強調的是結構化程序清晰易讀,可理解性好,程序員能夠進行逐步求精、程序證明和測試,以保證程序的正確性。本題答案為B。2、數據庫設計包...
-
JS控制html控件的方法
為了方便廣大計算機愛好者,下面YJBYS小編為大家整理了關於JS控制html控件的方法,希望對你有所幫助。方法一:《divid=myDiv》《/div》//容器varstrInnerHtml=《inputid=myInputtype=text》;//要添加的控件rHTML=strInnerHtml;//執行添加動作方法二:《divid=myDiv》...
-
2016年最新JAVA編程題及答案
【程序1】題目:打印出所有的"水仙花數",所謂"水仙花數"是指一個三位數,其各位數字立方和等於該數本身。例如:153是一個"水仙花數",因為153=1的三次方+5的三次方+3的三次方。1.程序分析:利用for循環控制100-999個數,每個數分解出個位,十位,百位。【程序2】題目:古典問題:有...
-
最全的java隨機數生成算法
java隨機數生成算法是怎麼樣的?下面yjbys小編為大家分享最新最全的java隨機數生成算法,希望對大家學習有所幫助!一個最全的隨機數的生成算法,最代碼的找回密碼的隨機數就是用的這個方法:1Stringpassword=rateString(10);源碼如下:001package;002003importom;004005...