zoukankan      html  css  js  c++  java
  • ArrayList和LinkedList

      集合List下有2个子类,分别为ArrayList和LinkedList。

      ArrayList:里面实际为数组,动态大小。即创建ArrayList时自动创建数组大小,在后续添加数据时,数组长度不够,会自动进行扩容。连续内存,增修查快、删除慢。下方分别是图形展示和部分实现代码。

     1 public class MyArrayList {
     2 
     3     Object[] objs = new Object[4];
     4     
     5     int size = 0;
     6     
     7     public void add(Object value) {
     8         
     9         //判断容量是否足够大,不够进行扩容
    10         if(size >= objs.length) {
    11             Object[] temp = new Object[objs.length*2];
    12             
    13             for(int i=0; i<objs.length; i++) {
    14                 temp[i] = objs[i];
    15             }
    16         }
    17         
    18         objs[size] = value;
    19         size++;
    20     }
    21     
    22 }
    View Code

        LinkedList:是不连续的内存,由数组和下一个结点的地址组成,头会特别标记,增修查慢、删除快。下方分别是图形展示和部分实现代码。

     1 //LinkedList中需要使用
     2 public class MyNode {
     3     
     4     Object value; //数据
     5     
     6     MyNode next;
     7     
     8     public MyNode(Object value) {
     9         this.value = value;
    10     }
    11 
    12     public Object getValue() {
    13         return value;
    14     }
    15 
    16     public void setValue(Object value) {
    17         this.value = value;
    18     }
    19 
    20     public MyNode getNext() {
    21         return next;
    22     }
    23 
    24     public void setNext(MyNode next) {
    25         this.next = next;
    26     }
    27     
    28 }
    View Code
     1 public class MyLinkedList {
     2     
     3     int size = 0;
     4     //换门标记第一个元素
     5     MyNode head = null;
     6     
     7     public void add(Object value) {
     8         MyNode node = new MyNode(value);
     9         
    10         if(null == head) {
    11             head = node;
    12         }else {
    13             MyNode temp = head;
    14             
    15             //得到最后一个结点,并把新的结点追加进去
    16             while(null != temp.getNext()) {
    17                 temp = temp.getNext();
    18             }
    19             temp.setValue(value);
    20         }
    21     }
    22 }
    View Code
  • 相关阅读:
    【excel】=EXACT(A1,B1) 比较两个字符串是否相等
    【oracle】oracle11g安装失败 提示找不到文件,模板General_Purpose.dbc不存在
    【oracle】11g服务器安装详细步骤
    【oracle】ceil函数 返回值 (大于参数的最小整数)
    【oracle】 months_between(date1,date2)
    javaWeb遍历获取session中的值
    tomcat+mysql数据库连接池的操作
    java中值得类型转化
    javaWeb图片验证码代码
    JSP与Servlet之间传值
  • 原文地址:https://www.cnblogs.com/yolandaBlog/p/9297477.html
Copyright © 2011-2022 走看看