当前位置: 首页 > news >正文

资源网站推荐长沙免费网站建站模板

资源网站推荐,长沙免费网站建站模板,php 网站开发模式,潍坊mip网站建设ArrayList、LinkedList、与Vector的区别 解读ArrayList 是一个可改变大小的数组LinkedList 是一个双向链表Vector 属强同步类 拓展知识面ArrayList是如何扩容?如何利用List实现LRU? 解读 List主要有ArrayList、LinkedList与Vector几种实现。这三者都实现…

ArrayList、LinkedList、与Vector的区别

  • 解读
    • ArrayList 是一个可改变大小的数组
    • LinkedList 是一个双向链表
    • Vector 属强同步类
  • 拓展知识面
    • ArrayList是如何扩容?
    • 如何利用List实现LRU?

解读

List主要有ArrayList、LinkedList与Vector几种实现。这三者都实现了List接口,使用方式也极其相似,主要区别在于因为实现方式的不同,所以对不同的操作就有不同的效率。

ArrayList 是一个可改变大小的数组

当,更多的元素加入到ArrayList中时,其大小将会动态的增长,内部的元素可以直接通过get与set方法进行访问,因为ArrayList本质上就是数组。

LinkedList 是一个双向链表

在添加和删除元素的时间具有比ArrayList更好的性能,但是在get与set方面是弱于ArrayList。当然了,这些对比都是指数据量很大或者操作很频繁的情况下的对比,如果数据量和运算量很小,那么就没有对比的意义。

Vector 属强同步类

Vector和ArrayList类似,但它属于强同步类。如果你的程序本身是线程安全的(thread-safe,没有在多个线程之间共享同一个集合或者对象),那么使用ArrayList是更好的选择。
Vector和ArrayList在更多元素添加进来时会请求更大的空间。Vector每次请求是它自身大小的双倍空间,而ArrayList每次对size增长50%。
而LinkedList还实现了Queue个Deque接口,该接口与List相比,其提供了更多的方法,包括offer()、peek()、poll()等。

注意:默认情况下ArrayList的初始容量非常小,所以如果可以预估数据量的话,分配一个较大的初始值才属于最佳操作,这样可以减少调整大小的开销。

拓展知识面

ArrayList是如何扩容?

首先,我们要明白ArrayList是基于数组的,这个上面讲到了,我们都知道,申请数组的时间,只能申请一个定长的数组,那么List是如何实现数组扩容的呢???ArrayList的扩容有几个步骤:

  1. 检查新增元素后是否会超过数组的容量,若超过,则进行下一步扩容;
  2. 设置新增容量为原始(旧/老)容量的1.5倍,最多不超过2^31-1(在Java8中ArrayList的容量最大是Integer.MAX_VALUE-8,这是由于在Java8中,ArrayList内部实现进行了一些改进,使用了一些数组复制的技巧来提高性能和内存的利用率,而这些技巧需要额外的8个元素的空间来进行优化)。
  3. 之后呢,申请一个容量为1.5倍的数组,将原有数组的元素复制到新数组中,自此,扩容完成。

如何利用List实现LRU?

LRU,即最近最少使用策略,基于时空局部性原理(最近访问的,未来也会被访问的),往往作为缓存淘汰的策略,如Redis和GuavaMap都使用了这种套胎策略。

我们可以基于LinkedList来实现LRU,因为LinkedList基于双向链表,每个节点都会记录上一个和下一个的节点,具体实现方式如下:

public class LruListCache<E> {private final int maxSize;private final LinkedList<E> list = new LinkedList<>();public LruListCache (int maxSize) {this.maxSize = maxSize;} public void add(E e) {if(list.size() < maxSize) {list.addFrist(e);}else{list.removeLast(); list.addFrist(e);}}public E get(int index) {E e = list.get(index);list.remove(e);add(e);return e;}@Overridepublic String toString() {return list.toString();}}

OK,如果不懂数组和链表的区别的话,随后我有一个专门的数据结构的专栏,会讲到栈和队列、数组和链表以及二叉树的遍历等等内容。会做详细解说。

http://www.ds6.com.cn/news/104929.html

相关文章:

  • html5怎么做简单的网站品牌营销策划包括哪些内容
  • 最新招总代理项目seo常用优化技巧
  • 常见的电子商务网站网址百度seo权重
  • 如何在搜索中找到自己做的网站淘宝关键词推广
  • 湘潭网站建设 磐石网络优质怎么创建个人网站
  • 自己网站视频直播怎么做搜狗网页版
  • 怎么做推广网站赌场广州seo运营
  • 杭州网站建设q479185700惠qq群推广网站免费
  • 触屏网站建设十大搜索引擎网站
  • 做网站首页可以用传媒公司吗国际购物网站平台有哪些
  • 电商类网站建设需要多少钱北京、广州最新发布
  • 网站建设 英文手机百度
  • 广告平面设计软件有哪些seo优化网络公司排名
  • 网站备案名称能重复吗seo营销优化软件
  • 网站上如何放入地图友情网
  • 网页设计与网站建设完全学习手册东莞互联网推广
  • 一级a做爰片免费网站 小说西安网站关键词优化费用
  • 北京网站制作与营销培训免费发链接的网站
  • wordpress wind谷歌seo 外贸建站
  • 网站有备案 去掉备案源码交易平台
  • 一台服务做两个网站吗苏州疫情最新情况
  • 公司网站用什么语言开发网络推广站
  • 股票做空网站企业推广方式有哪些
  • wordpress幻灯片的调用西安seo网站建设
  • 濮阳建网站的厦门人才网个人登录
  • 一个做外汇的网站叫熊猫什么的seo搜索引擎优化公司
  • 常用网站开发软件6定制网站和模板建站
  • wordpress 提速太原百度网站快速优化
  • 网站图片分辨率线上推广渠道
  • 腾讯企业邮箱网页版登录入口官网重庆网站seo服务