亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

帶你快速搞定java數(shù)組

 更新時間:2021年07月15日 08:44:58   作者:香菜聊游戲  
數(shù)組是相同類型數(shù)據(jù)的有序集合數(shù)組描述的是相同類型的若干個數(shù)據(jù),按照一定的先后次序排列組合而成。其中,每一個數(shù)據(jù)稱作一個數(shù)組元素,每個數(shù)組元素可以通過一個下標來訪問它們數(shù)組的聲明創(chuàng)建

1、數(shù)組的定義

  • 先聲明后使用

數(shù)據(jù)類型 [] 數(shù)組名稱 = new 數(shù)據(jù)類型[長度];String[] arr3 = new String[5];

數(shù)據(jù)類型 數(shù)組名稱[] = new 數(shù)據(jù)類型[長度];String arr[] = new String[5];

  • 直接初始化

String[] arrs = {"1","2","3"};

  • 聲明并初始化
String[] sarr = new String[]{"a","b"};

2、array 遍歷

  • 流遍歷

將數(shù)組封裝成流進行操作,所有的操作都和列表一樣操作

public static void main(String[] args) {
      String[] arrs = {"1","2","3"};
      Arrays.stream(arrs).forEach(System.out::println);
  }
  • 普通遍歷

普通遍歷有三種方式,建議使用第一種,

如果需要使用索引可以使用第三種

如果想要倒序,則使用第三種

圖片

3、List和array 之間的轉(zhuǎn)換

list 和 array 之間大有聯(lián)系,list 的實現(xiàn)形式有鏈表和 數(shù)組,我們開發(fā)中經(jīng)常需要對兩者進行轉(zhuǎn)換

1、數(shù)組轉(zhuǎn)list

  • 使用循環(huán) 轉(zhuǎn)換為list
  • 借助工具方法

代碼展示:

   public static void main(String[] args) {
       String[]  arrs = {"1","2","3"};
       // 循環(huán)轉(zhuǎn)換
       List<String> list1 = new ArrayList<>();
       for (String arr : arrs) {
           list1.add(arr);
      }
       // 借助數(shù)組工具類
       List<String> list2 = Arrays.asList(arrs);
       // 借助集合工具類
       List<String> list3 = new ArrayList<>();
       Collections.addAll(list2,arrs);
  }

2、list 轉(zhuǎn)數(shù)組

  • list 內(nèi)置方法 toArray
  • 直接循環(huán)

代碼展示

   public static void main(String[] args) {
       List<String> list = Arrays.asList("1","2");
       String[] arr1 = new String[list.size()];
       // 循環(huán)遍歷賦值
       for (int i = 0; i < list.size(); i++) {
           arr1[i] = list.get(i);
      }
       // 調(diào)用list 方法
       String[] arr2 = (String[]) list.toArray();
  }

3、Arrays工具類

  • toString()

打印數(shù)組的方法,如果不調(diào)用這個方法打印的是內(nèi)存地址

圖片

  • stream()

將數(shù)組轉(zhuǎn)換為流操作,具體就不演示了

  • sort()

對數(shù)組進行排序,注意這個排序是數(shù)組內(nèi)部排序,沒有返回值,原數(shù)組會被改變

  • setAll

對數(shù)組內(nèi)的元素進行操作,需要提供一個function,具有不同的數(shù)據(jù)類型

String[] arrs = {"1","2","3"};
      Arrays.setAll(arrs, e->e+"0");
      for (String arr : arrs) {
          System.out.println(arr);
      }
  • binarySearch

看名字都知道這是二分查找,具體的算法也很簡單,如果你還不會,可以補一下了,如果你懂二分查找應(yīng)該知道,在調(diào)用這個方法之前要保證數(shù)組是有序的!

  • copyOf

名字也很直白,拷貝數(shù)組,擴展就是增加一些長度限制,或者填充數(shù)據(jù)的設(shè)置

  • equals

看起來不需要解釋

  • deepEquals

判斷兩個數(shù)組的深度是否相同,也就是數(shù)組嵌套了幾層

    public static void main(String[] args) {
          String[] arrs = {"1","2","3"};
          String[][] arr2 = {{"1"},{"2"},{"3"}};
          boolean b = Arrays.deepEquals(arr2, arrs);
          System.out.println(b);
      }
  • fill

認識英語的話基本上都懂,就是如何填充數(shù)組,當然你也可以自己進行循環(huán)操作

  • hashCode

計算數(shù)組的hash code

  • parallelPrefix

這個有些意思的,并行的累計操作數(shù)組內(nèi)的元素,看個例子你就知道了

public static void main(String[] args) {
       String[]  sarr = new String[]{"a","b","c"};
       Arrays.parallelPrefix(sarr, (sum,e1)->e1 + sum);
       System.out.println(Arrays.toString(sarr));
  }

看下執(zhí)行結(jié)果:

圖片

4、可能遇到的問題

1、索引越界問題,數(shù)組的下標索引是從0 開始的,最后一個索引是length -1 ,注意不要越界

2、下面的方式創(chuàng)建的列表不支持添加

因為Arrays中的ArrayList并沒有實現(xiàn)remove()和add()方法,所以拋出了異常。所以說 Arrays.asList 返回的 List 是一個不可變長度的列表,此列表不再具備原 List 的很多特性,因此慎用 Arrays.asList 方法。

String[] arr = {"1", "2", "3"};
       List list = Arrays.asList(arr);
       arr[1] = "4";
       try {
           list.add("5");
      } catch (Exception ex) {
           ex.printStackTrace();
      }

3、一個小技巧,將數(shù)組繞成圈進行遍歷

使用對數(shù)組長度取余即可

   public static void main(String[] args) {
       String[] arr = {"a", "b", "c"};
       int i = 0;
       int j = 0;
       int length = arr.length;
       while (j++ <10){
           System.out.println(arr[i%length]);
           i++;
      }
  }

可以看到多次遍歷了數(shù)組

圖片

總結(jié)

本篇文章就到這里了,希望能給你帶來幫助,也希望你能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

最新評論