java 1_容器

慕课网  玩转数据结构1-数组 - 简书

容器(HashMap、HashSet、LinkedList、ArrayList、数组等)

在Java当中,如果有一个类专门用来存放其它类的对象,这个类就叫做容器,或者就叫做集合,集合就是将若干性质相同或相近的类对象组合在一起而形成的一个整体

一、LinkedList、ArrayList 区别和优缺点

ArrayList和linkedList的区别 - 阿晶 - 博客园(参考原作者地址)

1、Array(数组) 是基于索引的数据结构  get和set比较快速

Array 获取数据的时间复杂度O(1),但是删除数据开销比较大,需要重排数据(后面数据前移)

初始化时必须指定初始化长度,否则报错

例如:

int[] a = new int[4];

int c[] = {23,44,55,66};

2、List 是一个有序的集合,可以包含重复元素,提供了按索引访问的方式,继承 Collection

List 有两个重要的实现类:ArrayList和LinkedList

List 是一个接口,不可以被实例化,不能写成 List<Integer> list = new List<Integer>();

类继承关系

ArrayList : 可以看作是能够自动增长容量的数组

ArrayList的toArray方法返回一个数组。

ArrayList的asList方法返回一个列表

ArrayList底层的实现是Array,数组扩容实现

新增数据空间判断  新增数据的时候需要判断当前是否有空闲空间存储

扩容需要申请新的连续空间(2^n)

把老的数组复制过去

新加的内容

回收老的数组空间

package javatest;

import java.util.ArrayList;
import java.util.List;

/**
 * @ClassName Jtest
 * @Description TODO
 * @Author lingxiangxiang
 * @Date 4:54 PM
 * @Version 1.0
 **/
public class Jtest {

    public static int length = 1048576; //10的20次幂
    public static List<Integer> list1 = new ArrayList<>();
    public static List<Integer> list2 = new ArrayList<>(length);

    public static void addList(int sign) {
        long start = System.currentTimeMillis();
        for (int i = 0; i < length; i++) {
            if (sign == 0) {
                list1.add(sign);
            } else {
                list2.add(sign);
            }
        }
        long end = System.currentTimeMillis();
        System.out.println(sign + " exec time is: " + (end - start));
    }

    public static void main(String[] args) {
        addList(0);
        addList(1);
    }
}
0 exec time is: 25
1 exec time is: 17

ArrayList在初始化的时候指定长度肯定是要比不指定长度的性能好很多, 这样不用重复的申请空间, 复制数组, 销毁老的分配空间了

5、LinkList 是一个双链表,在添加和删除元素时具有比ArrayList更好的性能,但是在get和set方面弱于ArrayList.当然,这些对比都是指数据量很大或者操作很频繁。

链表不需要连续的空间,大小不确定

6、对比

时间复杂度

小结

  • 同样查找, 时间复杂度都是O(N), 但是数组要比链表快

    因为数组的连续内存, 会有一部分或者全部数据一起进入到CPU缓存, 而链表还需要在去内存中根据上下游标查找, CPU缓存比内存块太多

  • 数据大小固定, 不适合动态存储, 动态添加, 内存为一连续的地址, 可随机访问, 查询速度快

  • 链表代销可变, 扩展性强, 只能顺着指针的方向查询, 速度较慢

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值