Android基础回顾:Java基础拾遗(二)

65 阅读1分钟

这篇我们来复习下针对数组常用的一些方法。
1、优化过的快速排序法

*   int[] array = {11,12,232,32,23,18,34};
    
*   Arrays.sort(array);// 升序
    
*   System.out.println(Arrays.toString(array));  //  [11, 12, 18, 23, 32, 34, 232]

对数组中的元素,从第几个到第几个进行排序

*   int[] array = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   // 对数组中的元素,从第3个到第7个进行排序
    
*   Arrays.sort(array, 2, 7);
    
*   for (int i = 0; i < array.length; i++) {
    
*        System.out.println(array[i]);
    
*   }
    
*   // result=[7, 18, 3, 6, 10, 12, 32, 3, 5]

从结果我们可以看到是这样的一个区间"[...)",包括索引是2的元素,不包括索引是7的元素

2、二分查找法,返回元素在数组中的索引

*   int[] array = {11, 12, 32, 34, 28, 29, 100};
    
*   int index = Arrays.binarySearch(array, 32); 
    
*   System.out.println("index = " + index); // result=2

若是查找不到,则返回(-插入点-1)

*   int[] array = {11, 12, 32, 34, 28, 29, 100};
    
*   int index = Arrays.binarySearch(array, 23); 
    
*   System.out.println("index = " + index); // result=-3 (-3 = -2 - 1)

3、System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length);

*   int[] src = {1, 2, 3, 4, 5};
    
*   int[] dest = {18, 27};
    
*   // 第一个参数:原数组
    
*   // 第二个参数:从原数组的第几个元素开始取
    
*   // 第三个参数:目标数组
    
*   // 第四个参数:将从原数组中取到的第一个元素,存入目标数组的第几个元素
    
*   // 第五个参数:从原数组取几个数据,这个值的大小要小于等于目标数组的大小
    
*   System.arraycopy(src, 1, dest, 0, 2); // result=[2, 3]
    
*   for (int i = 0; i < dest.length; i++) {
    
*      System.out.println(dest[i]);
    
*   }

注意: 第五个参数,这个值要是大于目标数组的大小,就会报如下错误

*   Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException
    
*   at java.lang.System.arraycopy(Native Method)
    
*   at com.miliyo.test.Main.main(Main.java:25)

4、比较两个数组中的元素是否完全一致

*   int[] array1 = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   int[] array2 = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   boolean result = Arrays.equals(array1, array2);
    
*   System.out.println("result = " + result); // result = true

这篇我们来复习下针对数组常用的一些方法。
1、优化过的快速排序法

*   int[] array = {11,12,232,32,23,18,34};
    
*   Arrays.sort(array);// 升序
    
*   System.out.println(Arrays.toString(array));  //  [11, 12, 18, 23, 32, 34, 232]

对数组中的元素,从第几个到第几个进行排序

*   int[] array = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   // 对数组中的元素,从第3个到第7个进行排序
    
*   Arrays.sort(array, 2, 7);
    
*   for (int i = 0; i < array.length; i++) {
    
*        System.out.println(array[i]);
    
*   }
    
*   // result=[7, 18, 3, 6, 10, 12, 32, 3, 5]

从结果我们可以看到是这样的一个区间"[...)",包括索引是2的元素,不包括索引是7的元素

2、二分查找法,返回元素在数组中的索引

*   int[] array = {11, 12, 32, 34, 28, 29, 100};
    
*   int index = Arrays.binarySearch(array, 32); 
    
*   System.out.println("index = " + index); // result=2

若是查找不到,则返回(-插入点-1)

*   int[] array = {11, 12, 32, 34, 28, 29, 100};
    
*   int index = Arrays.binarySearch(array, 23); 
    
*   System.out.println("index = " + index); // result=-3 (-3 = -2 - 1)

3、System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length);

*   int[] src = {1, 2, 3, 4, 5};
    
*   int[] dest = {18, 27};
    
*   // 第一个参数:原数组
    
*   // 第二个参数:从原数组的第几个元素开始取
    
*   // 第三个参数:目标数组
    
*   // 第四个参数:将从原数组中取到的第一个元素,存入目标数组的第几个元素
    
*   // 第五个参数:从原数组取几个数据,这个值的大小要小于等于目标数组的大小
    
*   System.arraycopy(src, 1, dest, 0, 2); // result=[2, 3]
    
*   for (int i = 0; i < dest.length; i++) {
    
*      System.out.println(dest[i]);
    
*   }

注意: 第五个参数,这个值要是大于目标数组的大小,就会报如下错误

*   Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException
    
*   at java.lang.System.arraycopy(Native Method)
    
*   at com.miliyo.test.Main.main(Main.java:25)

4、比较两个数组中的元素是否完全一致

*   int[] array1 = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   int[] array2 = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   boolean result = Arrays.equals(array1, array2);
    
*   System.out.println("result = " + result); // result = true

这篇我们来复习下针对数组常用的一些方法。
1、优化过的快速排序法

*   int[] array = {11,12,232,32,23,18,34};
    
*   Arrays.sort(array);// 升序
    
*   System.out.println(Arrays.toString(array));  //  [11, 12, 18, 23, 32, 34, 232]

对数组中的元素,从第几个到第几个进行排序

*   int[] array = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   // 对数组中的元素,从第3个到第7个进行排序
    
*   Arrays.sort(array, 2, 7);
    
*   for (int i = 0; i < array.length; i++) {
    
*        System.out.println(array[i]);
    
*   }
    
*   // result=[7, 18, 3, 6, 10, 12, 32, 3, 5]

从结果我们可以看到是这样的一个区间"[...)",包括索引是2的元素,不包括索引是7的元素

2、二分查找法,返回元素在数组中的索引

*   int[] array = {11, 12, 32, 34, 28, 29, 100};
    
*   int index = Arrays.binarySearch(array, 32); 
    
*   System.out.println("index = " + index); // result=2

若是查找不到,则返回(-插入点-1)

*   int[] array = {11, 12, 32, 34, 28, 29, 100};
    
*   int index = Arrays.binarySearch(array, 23); 
    
*   System.out.println("index = " + index); // result=-3 (-3 = -2 - 1)

3、System.arraycopy(Object src, int srcPos, Object dest, int destPos, int length);

*   int[] src = {1, 2, 3, 4, 5};
    
*   int[] dest = {18, 27};
    
*   // 第一个参数:原数组
    
*   // 第二个参数:从原数组的第几个元素开始取
    
*   // 第三个参数:目标数组
    
*   // 第四个参数:将从原数组中取到的第一个元素,存入目标数组的第几个元素
    
*   // 第五个参数:从原数组取几个数据,这个值的大小要小于等于目标数组的大小
    
*   System.arraycopy(src, 1, dest, 0, 2); // result=[2, 3]
    
*   for (int i = 0; i < dest.length; i++) {
    
*      System.out.println(dest[i]);
    
*   }

注意: 第五个参数,这个值要是大于目标数组的大小,就会报如下错误

*   Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException
    
*   at java.lang.System.arraycopy(Native Method)
    
*   at com.miliyo.test.Main.main(Main.java:25)

4、比较两个数组中的元素是否完全一致

*   int[] array1 = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   int[] array2 = {7, 18, 32, 3, 12, 10, 6, 3, 5};
    
*   boolean result = Arrays.equals(array1, array2);
    
*   System.out.println("result = " + result); // result = true

关注公众号:Android老皮
解锁  《Android十大板块文档》 ,让学习更贴近未来实战。已形成PDF版

内容如下

1.Android车载应用开发系统学习指南(附项目实战)
2.Android Framework学习指南,助力成为系统级开发高手
3.2023最新Android中高级面试题汇总+解析,告别零offer
4.企业级Android音视频开发学习路线+项目实战(附源码)
5.Android Jetpack从入门到精通,构建高质量UI界面
6.Flutter技术解析与实战,跨平台首要之选
7.Kotlin从入门到实战,全方面提升架构基础
8.高级Android插件化与组件化(含实战教程和源码)
9.Android 性能优化实战+360°全方面性能调优
10.Android零基础入门到精通,高手进阶之路

敲代码不易,关注一下吧。ღ( ´・ᴗ・` ) 🤔