zoukankan      html  css  js  c++  java
  • java中Arrays的用法

    Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。

    数组复制

    使用System.arraycopy进行数组复制类似的, Arrays提供了一个copyOfRange方法进行数组复制。

    不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。
    除此之外,需要注意的是 copyOfRange 的第3个参数,表示源数组的结束位置,是取不到的。
    import java.util.Arrays;
    
    public class HelloWorld {
    	public static void main(String[] args) {
    		int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
    
    		// copyOfRange(int[] original, int from, int to)
    		// 第一个参数表示源数组
    		// 第二个参数表示开始位置(取得到)
    		// 第三个参数表示结束位置(取不到)
    		int[] b = Arrays.copyOfRange(a, 0, 3);
    
    		for (int i = 0; i < b.length; i++) {
    			System.out.print(b[i] + " ");
    		}
    
    	}
    }
    

      而用System.arraycopy进行复制的话如下

    public class HelloWorld {
        public static void main(String[] args) {
            int a [] = new int[]{18,62,68,82,65,9};
             
            int b[] = new int[3];//分配了长度是3的空间,但是没有赋值
             
            //通过数组赋值把,a数组的前3位赋值到b数组
             
            //方法一: for循环
             
            for (int i = 0; i < b.length; i++) {
                b[i] = a[i];
            }
            
            //方法二: System.arraycopy(src, srcPos, dest, destPos, length)
            //src: 源数组
            //srcPos: 从源数组复制数据的启始位置
            //dest: 目标数组
            //destPos: 复制到目标数组的启始位置
            //length: 复制的长度       
            System.arraycopy(a, 0, b, 0, 3);
             
            //把内容打印出来
            for (int i = 0; i < b.length; i++) {
                System.out.print(b[i] + " ");
            }
     
        }
    }
    

      

    二 转换为字符串

    如果要打印一个数组的内容,就需要通过for循环来挨个遍历,逐一打印但是Arrays提供了一个toString()方法,直接把一个数组,转换为字符串,这样方便观察数组的内容

    import java.util.Arrays;
      
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
            String content = Arrays.toString(a);
            System.out.println(content);
      
        }
    }
    

     三排序

    Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。

    import java.util.Arrays;
      
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
            System.out.println("排序之前 :");
            System.out.println(Arrays.toString(a));
            Arrays.sort(a);
            System.out.println("排序之后:");
            System.out.println(Arrays.toString(a));
      
        }
    }
    

      四 搜索

      查询元素出现的位置
    需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序
    如果数组中有多个相同的元素,查找结果是不确定的

    import java.util.Arrays;
     
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
     
            Arrays.sort(a);
     
            System.out.println(Arrays.toString(a));
            //使用binarySearch之前,必须先使用sort进行排序
            System.out.println("数字 62出现的位置:"+Arrays.binarySearch(a, 62));
        }
    }
    

      五 判断是否相同

    比较两个数组的内容是否一样
    第二个数组的最后一个元素是8,和第一个数组不一样,所以比较结果是false

    import java.util.Arrays;
     
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
            int b[] = new int[] { 18, 62, 68, 82, 65, 8 };
     
            System.out.println(Arrays.equals(a, b));
        }
    }
    

      六填充

    使用同一个值,填充整个数组

    import java.util.Arrays;
      
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[10];
      
            Arrays.fill(a, 5);
      
            System.out.println(Arrays.toString(a));
      
        }
    }
    

      编辑较为混乱 日后再重新整理

  • 相关阅读:
    初识spring boot
    javascript的console命令
    (转)三角函数计算,Cordic 算法入门
    (原+转)ROC曲线
    (转)(VS2013 )由于应用程序配置不正确,程序未能启动”--原因及解决方法
    (转)最小二乘法拟合圆公式推导及vc实现[r]
    (原)Eclipse中将JNI生成的so打包成jar的步骤
    (原)Eclipse的java中文件读写
    (原)Microsoft Source Reader的简单使用
    (转)android ndk 给结构体赋值的方法
  • 原文地址:https://www.cnblogs.com/loufangcheng/p/10531467.html
Copyright © 2011-2022 走看看