java基礎知識4--數組的常用方法(Array)


先說一個idea編輯器的問題,編輯器的光標變成黑色光標無法移動,按一下insert鍵就好了。

數組是線性數據存儲結構、它用犧牲自動擴展大小來換取與集合相比的唯一優勢——查詢效率的提升。本身是一種引用類型的數據、所以我們要使用數組就要首先聲明、初始化他、而它的初始化的完成也就意味着此數組的大小將不再改變、而且具有初始值。 定義數組必須給定數組的大小。Java中的數組長度不變!存儲的數據類型唯一
 
數組的引用存放在棧內、實際對象存放在堆內存中。
 
常用的方法可如下:
1.數組的定義和聲明(必須給定數組大小!!!!!)
/*1.定義數組,必須規定數組的大小,優點:查詢效率高 */

        // Arrays.fill(數組名,值)主要是將數組中每個元素賦予相同的值, // 該方法通過各種重載形式可完成任意類型的數組元素的替換
        String[] s1 = new String[4]; Arrays.fill(s1, "wyy"); for (String s : s1 ) { System.out.println(s); }
String s2[]
= {"wyy", "wzz", "wxx"}; System.out.println(Arrays.toString(s2));//注意:直接輸出s2只能得到數組的地址引用 String[] s3 = new String[]{"zyy", "zxx", "zww"}; System.out.println(Arrays.toString(s3)); //將字符串數組轉化為字符串 int[] s5 = new int[]{7, 3, 2, 8, 9};

2.將數組轉化為集合(set,list)

(1)轉化為list

 /*2.將數組轉化為ArrayList Arrays.asList(數組) */ List<String> list = new ArrayList<>(Arrays.asList(s2)); list.add("whh"); System.out.println("ArrayList是否包含:" + list.contains("whh"));

(2)轉化為set

        Set<String> set = new HashSet<>(Arrays.asList(s2)); System.out.println("集合set是否包含:" + set.contains("wyy"));

(3)整型數組轉化

特別注意,將整形數組轉為集合,必須用原始類型。不能直接將int[]轉化為集合、因為asList()方法的參數必須是對象。應該先把int[]轉化為Integer[]。對於其他原始的類型的數組也是如此,必須先轉換成相應的包裝類類型數組。

Java是面向對象的編程語言,也就說一切皆為對象.可是那些int double 等八種數據類型卻不是對象,這就與Java的一切皆是對象的思想相矛盾了,所以為了解決這個問題,Java就出現了包裝類,把那些基本數據類型進行包裝,讓它成為了一個類,等用到的時候直接調用就可以了..因為集合的類型必須為對象,所以添加元素類型必須為原始類

public interface Set<E> extends Collection<E> 
       Integer[] integerArray = new Integer[s5.length]; for (int i = 0; i < integerArray.length; i++) { integerArray[i] = s5[i]; } Set<Integer> set1 = new HashSet<>(Arrays.asList(integerArray)); System.out.println(set1); //[2, 3, 7, 8, 9]

3.數組是否包含某個元素    Arrays.toString(s2).contains   轉化為字符串,然后用contain方法

 /*3.數組是否包含某個元素,用Arrays.toString(s2),然后直接用字符串.contain方法*/ System.out.println("字符串是否包含:" + Arrays.toString(s2).contains("wyx"));

4.轉換int值為字節數組

 byte[] bytes = ByteBuffer.allocate(4).putInt(90).array(); for (byte t : bytes) { System.out.format("0x%x ", t);  //0x0 0x0 0x0 0x5a
        }

5.延伸:如何查看數組是否包含某個元素

方法1:Arrays.toString(s2).contains   轉化為字符串,然后用contain方法

方法2:先用2,轉化為集合,然后用contain方法

方法3:自循環

public static boolean Loop(String[] arr, String targetValue) { for(String s: arr){ if(s.equals(targetValue)) return true; } return false; }

方法4:Arrays.binarySearch()  ,只能用於有序數組,當數組存儲數據很多時推薦此方法。

可以通過計算 long time=System.nanoTime() 計算一下時間復雜度。

 public static boolean binarySearch(String[] arr, String targetValue) { int j = Arrays.binarySearch(arr, targetValue); if (j > 0) { return true; } else
            return false; }

6.另外 Apache common lang 包中的ArrayUtils類常用來連接兩個數組,數組元素移除,反轉 ,用時再說~

 

就醬紫~

 
 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM