【Java】ArrayList 底层原理,自己实现ArrayList

实现的功能有 

  • elementData对象数组用来存放对象
  • size 计算容器大小
  • ArrayList空构造器,带初始大小的构造器
  • ensureCapacity进行对象数组扩容
  • rangeCheck进行检查输入值是否在范围内
  • get方法返回某一位置对象
  • set方法修改某一位置对象
  • add方法在结尾增加对象,在指定位置增加对象
  • remove删除制定位置对象,删除与传参对象相同的对象
import java.util.ArrayList;
import java.util.List;

/**
 * 自己实现一个arraylist,学习底层实现与结构
 * @author 袁盛桐
 */
 public class MyArrayList{
    /**
     * 对象数组
     */
    private Object[] elementData;
    
    /**
     * 容器大小
     */
    private int size;

    /**
     * 返回elementData的size
     */
    public int size(){
        return this.size;
    }

    /**
     * 空构造器,初始长度为10
     */
    public MyArrayList(){
        this(10);
    }

    /**
     * initialCapacity是初始容器长度
     */
    public MyArrayList(int initialCapacity){
        if(initialCapacity < 0){
            try {
                throw new Exception();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        elementData = new Object[initialCapacity];
    }

    /**
     * 数组扩容
     */
    private void ensureCapacity(){
        if(size == elementData.length){
            //扩容操作
            Object[] newArray = new Object[size*2+1];
            //从老数组elementData数组的0位置拷贝到新数组newArray的0位置,拷贝长度为elementData.length
            System.arraycopy(elementData,0,newArray,0,elementData.length);
            elementData = newArray;
        }
    }

    /**
     * 检查输入的index是否在范围内
     */
    public void rangeCheck(int index){
        if(index<0||index>=size){
            try {
                throw new Exception();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }

    /**
     * 返回某一位置对象
     */
    public Object get(int index){
        rangeCheck(index);
        return elementData[index];
    }

    /**
     * 修改对象
     */
    public Object set(int index, Object obj){
        rangeCheck(index);
        Object oldValue = elementData[index];
        elementData[index] = obj;
        return oldValue;
    }

    /**
     * add方法,增加对象
     */
    public void add(Object obj){
        //数组扩容
        ensureCapacity();
        //先赋值后自增
        elementData[size++] = obj;
    }

    /**
     * 在指定位置增加对象
     */
    public void add(int index, Object obj){
        rangeCheck(index);
        //数组扩容
        ensureCapacity();
        System.arraycopy(elementData,index,elementData,index+1,size-index);
        elementData[index] = obj;
        size++;
    }

    /**
     * 删除指定位置对象
     * nummoved是判断制定元素是否在中间,如果在中间nummoved是要后面元素提前的数量
     * 把最后一个元素设为null
     */
    public void remove(int index){
        rangeCheck(index);
        int numMoved = size - index - 1;
        if(numMoved > 0){
            System.arraycopy(elementData,index+1,elementData,index,numMoved);
        }
        elementData[--size] = null;
    }

    /**
     * 删除与obj相同的对象
     */
    public void remove(Object obj){
        for(int i=0;i<size;i++){
            if(get(i).equals(obj)){
                remove(i);
            }
        }
    }

    
 }

 

### 如何使用 Keil5 Hex 文件 对于仅拥有已编译好的 hex 文件而无源文件的情况,在 Keil V5 平台上直接hex 文件至单片机(如华大单片机)需采取特定的方法,因为直接调用该平台进行此类操作不可行[^1]。 #### 设置 Output 路径 进入 Keil 的 output 设置界面,指定要录的 hex 文件的具体位置。确保在路径输入框中填完整的 hex 文件名称并附带 `.hex` 扩展名;缺少此扩展名可能导致系统继续尝试录先前编译的结果而非所选的 hex 文件[^3]。 #### 配置 Flash 工具选项 针对不同类型的微控制器(MCU),可能还需调整 flash 下载工具的相关配置参数以匹配目标设备的要求。这一步骤通常涉及选择合适的编程算法以及设定通信接口等细节[^2]。 #### 启动下载过程 完成上述准备工作之后,可以通过点击调试窗口内的 “Download” 或者快捷菜单里的相应命令来启动实际的程序入流程。如果一切顺利的话,软件会自动连接硬件并将选定的 hex 数据传输到 MCU 中存储起来[^4]。 ```python # Python 示例代码用于说明自动化脚本概念 (并非真实实现) def download_hex_to_mcu(hex_file_path, mcu_type): """ 自定义函数模拟将 HEX 文件下载到指定型号的 MCU 上 参数: hex_file_path -- 完整路径字符串指向待上传的 .hex 文件 mcu_type -- 字符串表示的目标单片机类型标识符 返回值: 成功则返回 True ,失败抛出异常信息 """ try: configure_output_settings(hex_file_path) # 设定输出设置 select_flash_tool(mcu_type) # 挑选适合的闪存工具 execute_download_command() # 发送下载指令 return True # 表明成功结束 except Exception as e: raise RuntimeError(f"Failed to upload {hex_file_path}: {e}") ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值