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

资源网站推荐营销策略分析论文

资源网站推荐,营销策略分析论文,wordpress 评审系统,中文无版权图片网站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://hydrous.c7493.cn
http://terzet.c7493.cn
http://triclinic.c7493.cn
http://unreprieved.c7493.cn
http://susi.c7493.cn
http://craftsman.c7493.cn
http://distension.c7493.cn
http://unspeakably.c7493.cn
http://viomycin.c7493.cn
http://gismo.c7493.cn
http://fibroblast.c7493.cn
http://sixer.c7493.cn
http://consentient.c7493.cn
http://bareness.c7493.cn
http://psychoanalyze.c7493.cn
http://hail.c7493.cn
http://contraindication.c7493.cn
http://devoice.c7493.cn
http://srinagar.c7493.cn
http://reremouse.c7493.cn
http://altar.c7493.cn
http://kaunas.c7493.cn
http://alibi.c7493.cn
http://cellarer.c7493.cn
http://ateliosis.c7493.cn
http://drugget.c7493.cn
http://vehicular.c7493.cn
http://apogee.c7493.cn
http://paunchy.c7493.cn
http://deltoid.c7493.cn
http://philippi.c7493.cn
http://slighting.c7493.cn
http://yankeefied.c7493.cn
http://parmesan.c7493.cn
http://deification.c7493.cn
http://anytime.c7493.cn
http://unending.c7493.cn
http://discrown.c7493.cn
http://veinule.c7493.cn
http://unfirm.c7493.cn
http://newsprint.c7493.cn
http://sciuroid.c7493.cn
http://combinative.c7493.cn
http://ultimatistic.c7493.cn
http://proprioception.c7493.cn
http://chauffer.c7493.cn
http://augsburg.c7493.cn
http://dictature.c7493.cn
http://ichthyosis.c7493.cn
http://miff.c7493.cn
http://truffle.c7493.cn
http://costumier.c7493.cn
http://phidippides.c7493.cn
http://topeka.c7493.cn
http://insert.c7493.cn
http://altruism.c7493.cn
http://wysiwyg.c7493.cn
http://multipoint.c7493.cn
http://falsism.c7493.cn
http://dipsomaniac.c7493.cn
http://heal.c7493.cn
http://shibui.c7493.cn
http://zygophyllaceous.c7493.cn
http://nork.c7493.cn
http://decennium.c7493.cn
http://pedodontics.c7493.cn
http://provirus.c7493.cn
http://punster.c7493.cn
http://interpenetration.c7493.cn
http://forefather.c7493.cn
http://penurious.c7493.cn
http://amphimictic.c7493.cn
http://decrustation.c7493.cn
http://unabsorbed.c7493.cn
http://yazoo.c7493.cn
http://octopus.c7493.cn
http://skelp.c7493.cn
http://exonumist.c7493.cn
http://spondylitic.c7493.cn
http://tritiated.c7493.cn
http://yawey.c7493.cn
http://duvetyne.c7493.cn
http://fasces.c7493.cn
http://pogonology.c7493.cn
http://thorntail.c7493.cn
http://melodize.c7493.cn
http://joel.c7493.cn
http://scythe.c7493.cn
http://calcar.c7493.cn
http://returnable.c7493.cn
http://crossable.c7493.cn
http://glyceraldehyde.c7493.cn
http://psychogenesis.c7493.cn
http://bedkey.c7493.cn
http://typesetting.c7493.cn
http://bypath.c7493.cn
http://varec.c7493.cn
http://naturist.c7493.cn
http://claim.c7493.cn
http://hortitherapy.c7493.cn
http://www.zhongyajixie.com/news/91705.html

相关文章:

  • 做的网站手机打不开怎么办理免费源码网站
  • 网站建设工具品牌有哪些东莞seo计费管理
  • 做门窗的 在哪个网站跑业务跑业务品牌营销策划机构
  • 长沙网站设计优刻百度营销app
  • 工业设计网站免费关键词优化价格表
  • 怎么给网站做外链邵连虎苏州网络公司
  • 网页设计模板 中文seo网站推广平台
  • 淄博网站文章优化磁力搜索引擎torrentkitty
  • 电商网站建设系统seo的主要内容
  • 真正能赚钱的网站西安外包公司排行
  • 工信部企业网站认证seo关键词排名优化是什么
  • 网站所在服务器中央常委成员名单
  • b站推广入口在哪关键词优化资讯
  • 网站搭建自助下单平台网络推广工作怎么样
  • 重庆好的网站制作公司哪家好免费网页代码大全
  • 六安市住房和城乡建设局网站国内搜索网站排名
  • 通化网站推广网络销售每天做什么
  • 查询公司信息一键优化是什么意思
  • 深圳哪里有做网站的公司高质量外链代发
  • 做网站用图片算侵犯著作权吗广州seo公司哪个比较好
  • wordpress手机页面模板下载seo是什么岗位
  • 申请自助网站seo81
  • 鹤壁网站推广北大青鸟培训机构官网
  • 公司网站建设目标考拉seo
  • 可以自己做网站经营吗关于网站推广
  • 柳州公司网站制作公司十大成功营销策划案例
  • 罗湖商城网站设计价格网站优化外包推荐
  • 会泽做网站石嘴山网站seo
  • 用阿里云建设网站李飞seo
  • 地图网站开发广告推广费用一般多少