面试系列:常见的容器list和map简单介绍

Android 列表数据结构一般常用两种ArrayList和LinkedList

两种列表结构主要是根据不同的需求选用。

  1. ArrayList的底层是数组结构,多用于查询。这应该也是我们最长使用的数据结构了,因为android中的列表展示数据过于多,配合ListView和RecyclerView使用。
  2. LinkedList的底层是链表结构,多用于数据操作,插入和删除,这个目前使用频率比较低,如过不确定必须要用这个的话,建议使用ArrayList一般不会有问题。

常用的map为HashMap和HashTable

两种列表结构主要是根据不同的需求选用。

  1. HashMap的HashMap元素是可以为null的。HashMap底层就是一个Entry数组,Entry包含键和值,这里我们也常用这个,比如我们项目中存放的购物车商品就是通过一个全局的静态HashMap来进行存储。

    注意事项

    在使用HashMap的时候会有可能产生哈希冲突,HashMap的底层结构是一个哈希值对应一个Entry对象,当产生一个hash值对应多个Entry值,哈希值就对应的一个单向链表的Entry,这个时候调用get方法取值的时候,会去查询链表

  2. HashTable的元素是不能为空的,并且线程是安全的。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值