• Arrays.copyOf()方法说明


    调用Arrays.copyOf()方法会在堆中重新分配内存创建数组
     
    代码翻译:
    /传入原有数组对象,传入要截取的长度
        public static <T> T[] copyOf(T[] original, int newLength) {
            return (T[]) copyOf(original, newLength, original.getClass());
        }
        
        //传入原有数组对象,传入要截取的长度、数组中的类newType
        public static <T,U> T[] copyOf(U[] original, int newLength, Class<? extends T[]> newType) {
            @SuppressWarnings("unchecked")
            //新建一个长度为newLenth的数组
            T[] copy = ((Object)newType == (Object)Object[].class)
                ? (T[]) new Object[newLength]
                : (T[]) Array.newInstance(newType.getComponentType(), newLength);
            //通过System.arraycopy方法将原有数组拷贝到新的数组中,最后返回新数组
            System.arraycopy(original, 0, copy, 0,
                             Math.min(original.length, newLength));
            return copy;
        }
    测试:
        public static void main(String[] args) {
            String[] arrayOld = {"1","2"};
            System.out.println(JSONObject.toJSONString(arrayOld));
            System.out.println("arrayOld="+arrayOld);
            String[] araryNew = arrayOld;
            System.out.println(JSONObject.toJSONString(araryNew));
            System.out.println("araryNew="+araryNew);
            String[] araryCopy = Arrays.copyOf(araryNew, araryNew.length);
            System.out.println(JSONObject.toJSONString(araryCopy));
            System.out.println("araryCopy="+araryCopy);
        }
    执行结果:
    ["1","2"]
    arrayOld=[Ljava.lang.String;@60f82f98
    ["1","2"]
    araryNew=[Ljava.lang.String;@60f82f98
    ["1","2"]
    araryCopy=[Ljava.lang.String;@35f983a6
     
    arrayOld与araryCopy对象不同,说明 Arrays.copyOf()会在堆中重新分配内存创建数组
    收藏文章数量从多到少与“把书读薄”是一个道理
  • 相关阅读:
    GhostScript命令参数详解(转)
    西安电子科技大学week02-问题规约表示及其搜索技术
    西安电子科技大学week01-状态空间表示及其问题解决
    canal同步mysql数据
    Navicat连接mysql数据库报错2003
    fieldset可以实现在虚线框中写文字
    CSS盒模型简单介绍
    js变量数组和对象常用方法
    js数组方法大全
    IIFE和闭包和let
  • 原文地址:https://www.cnblogs.com/use-D/p/9628119.html
Copyright © 2020-2023  润新知