10.利用反射进行数组扩容

利用反射,我们无需再编写复杂的数组操作方法来进行数组的扩容,反射为我们提供了更为简便,效率更高的方式进行数组扩容。

1.关键方法

//这个方法用来判断一个class是否是数组类型的
calzz.isArray()
//这个方法用来获得数组存储的元素类型
Class<?> componentType = clazz.getComponentType();
//这个方法用来计算数组的长度的
int length = Array.getLength(array);
 //此方法用于新建一个存储类型为componentType的数组,空间长度为length+5
Object newArray = Array.newInstance(componentType, length + 5);
// 复制原来数组中的索引从0到length-1的数据到新数组中去
System.arraycopy(array, 0, newArray, 0, length);

2.实例学习

package ReflectStudy.Exa10;
import java.lang.reflect.Array;
import java.util.Arrays;
/**
 * 使用反射进行数组扩容操作
 */
public class UsefulArray {
    /**
     * 数组扩容
     * @param array 数组对象引用
     * @return 扩容后的数组引用
     */
    public static Object increaseArray(Object array) {
        // 获得代表数组的Class对象
        Class<?> clazz = array.getClass();
        // 如果输入是一个数组,则进行扩容
        if (clazz.isArray()) {
            // 获得数组元素的类型
            Class<?> componentType = clazz.getComponentType();
            // 获得输入的数组的长度
            int length = Array.getLength(array);
            // 新建数组,空间增加5个
            Object newArray = Array.newInstance(componentType, length + 5);
            // 复制原来数组中的所有数据
            System.arraycopy(array, 0, newArray, 0, length);
            // 返回新建数组
            return newArray;
        }
        // 如果输入的不是数组就返回空
        return null;
    }
    public static void main(String[] args) {
        int[] intArray = new int[10];
        System.out.println("整型数组原始长度是:" + intArray.length);
        Arrays.fill(intArray, 8);
        System.out.println("整型数组的内容:");
        System.out.println(Arrays.toString(intArray));
        int[] newIntArray = (int[]) increaseArray(intArray);
        System.out.println("整型数组扩展后长度是:" + newIntArray.length);
        System.out.println("整型数组的内容:");
        System.out.println(Arrays.toString(newIntArray));
    }
}

在这里插入图片描述
https://gitee.com/yan-jiadou/study/tree/master/Java%E5%8A%A8%E6%89%8B%E5%81%9A%E4%B8%80%E5%81%9A/src/main/java/ReflectStudy

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员小牧之

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值