百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

【一分钟学Java】之List

toyiye 2024-06-21 12:05 8 浏览 0 评论

概述

Java中List知识点主要涵盖ArrayList、LinkedList实现,需要理解实现逻辑,及实际使用场景。另外在JUC中需要注意线程安全问题。

List面试高频知识点

ArrayList

Java可动态扩容数组的实现。底层动态扩容数组,更适合快速查找(随机访问),不适合频繁新增删除

  • ArrayList 有最大容量的,为 Integer 的最大值(2^31-1),大于这个值 JVM 是不会为数组分配内存空间的
  • 可添加删除null,删除null找到第一个值删除

ArrayList的动态扩容

效果

  • 使用者不用关心底层数据结构的变化,封装得很好
  • 1.5 倍的扩容速度,可以让扩容速度在前期缓慢上升,在后期增速较快
  • 大部分工作中要求数组的值并不是很大,所以前期增长缓慢有利于节省资源,在后期增速较快时,也可快速扩容。

扩容步骤

  1. 初始默认0,添加一个元素后,变为10
  2. 每次扩容的大小为原来的一半(>>1 向右位移运算(除以2取整),再加上增量),1.5倍扩容例如:10+10>>1=15, 15+15>>1=22, 22+22>>1=33

注意

  • addAll 如果一次加入的元素量大于扩容量,就直接扩容到需要的大小
  • 拷贝很大的数组,可一开始就指定ArrayList(容量),避免频繁扩容。频繁扩容就会有大量拷贝的工作,造成拷贝的性能低下

LinkedList

底层双向链表。可用于实现队列与栈

添加元素需要判空

  • LinkedList 更适合于经常新增和删除,对查询反而很少的场景。
  • 理论上可以无限大。LinkedList 实际大小(下标)用的是 int 类型,这也说明了 LinkedList 不能超过 Integer 的最大值,不然会溢出。
  • 允许插入删除null,但作为Queue实现最好加判断拦截,否则无法区分poll是null还是异常

队列的实现

入队元素需要判空

入队元素需要判空

栈的实现

线程安全问题

重点CopyOnWriteArrayList

手动复现

一个线程往List里添加,另一个线程遍历输出。

问题和异常

多线程下,共享变量,导致并发修改异常,ConcurrentModificationException

解决方案一

  • Vector类的所有?法都是同步的。可以由两个线程安全地访问?个Vector对象,但是?个线程访问Vector的话代码要在同步操作上耗费?量的时间,性能低。
  • 利用Collections工具类实现。Synchronized是依赖于JVM实现的,非公平锁。

解决方案二(推荐)

  • CopyOnWriteArrayList写时复制技术。是Arraylist的一种线程安全变体,其中所有可变操作(add、set等)都是通过生成底层数组的新副本来实现的。同时满足写和读,读写分离。
  • 并发操作中使用ReenTrantLock,是JDK实现的,公平锁。写时复制技术

遍历

  • 迭代器迭代中不使用list.remove(e),使用iterator.remove()删除元素
  • for 效率低
  • forEach
  • stream流 配合stream中的各个方法

关于【一分钟学Java】

【一分钟学Java】是一个巩固Java基础知识的文档集合。

每天一分钟,碎片化学习,面试复习,助你上岸!!!

相关推荐

Asterisk-ARI对通道中的DTMF事件处理

Asterisk通道中关于DTMF处理是一个非常重要的功能。通过DTMF可以实现很多的业务处理。现在我们介绍一下关于ARI对通道中的DTMF处理,我们通过自动话务员实例来说明Asterisk如何创建一...

PyQt5 初次使用(pyqt5下载官网)

本篇文章默认已安装Python3,本篇文章默认使用虚拟环境。安装pipinstallPyQt5PyQt一些图形界面开发工具QtDesigner、国际化翻译工具Liguist需要另外...

Qt开发,使用Qt for Python还是Qt C++ Qt开发,使用Qt for

Qt开发使用QtforPython还是QtC++?1.早些年写过一个PyQt5的项目,最近几年重构成QtC++了,其中有个人原因,如早期代码写得烂,...

最简单方法!!用python生成动态条形图

最近非常流行动态条形图,在B站等视频网站上,此类视频经常会有上百万的播放量,今天我们通过第三方库:bar_chart_race(0.2版本)来实现动态条形图的生成;生成的效果如图:问题:...

Asterisk通道和ARI接口的通信(aau通道数)

Asterisk通道和ARI详解什么是通道Asterisk中,通道是介于终端和Asterisk自己本身的一个通信媒介。它包含了所有相关信息传递到终端,或者从终端传递到Asterisk服务器端。这些信...

Python GUI-长链转短链(长链接转化成短链接java)

当我们要分享某一个链接给别人,或是要把某个链接放入帖子中时,如果链接太长,则会占用大量空间,而且很不美观。这时候,我们可以结束长链转短链工具进行转换。当然可以直接搜索在线的网站进行转换,但我们可以借此...

Python 的hash 函数(python的hash函数)

今天在看python的hash函数源码的时候,发现针对不同的数据类型python实现了不同的hash函数,今天简单介绍源码中提到的hash函数。(https://github.com/pyth...

8款Python GUI开源框架,谁才是你的菜?

作为Python开发者,你迟早都会用到图形用户界面来开发应用。本文千锋武汉Python培训小编将推荐一些PythonGUI框架,希望对你有所帮助。1、Python的UI开发工具包Kivy...

python适合开发桌面软件吗?(python可不可以开发桌面应用软件)

其实Python/Java/PHP都不适合用来做桌面开发,Java还是有几个比较成熟的产品的,比如大名鼎鼎的Java集成开发环境IntelliJIDEA、Eclipse就是用Java开发的,不过PH...

CryptoChat:一款功能强大的纯Python消息加密安全传输工具

关于CryptoChatCryptoChat是一款功能强大的纯Python消息加密安全传输工具,该工具专为安全研究专家、渗透测试人员和红蓝队专家设计,该工具可以完全保证数据传输中的隐私安全。该工具建立...

为什么都说Python简单,但我觉得难?

Python普遍被大家认为是编程语言中比较简单的一种,但有一位电子信息的学生说自己已经学了C语言,但仍然觉得Python挺难的,感觉有很多疑问,像迭代器、装饰器什么的……所以他提出疑问:Python真...

蓝牙电话-关联FreeSwitch中继SIP账号通过Rest接口

蓝牙电话-关联FreeSwitch中继SIP账号通过Rest接口前言上一篇章《蓝牙电话-与FreeSwitch服务器和UA坐席的通话.docx》中,我们使用开源的B2B-UA当中经典的FreeSWIT...

技术分享|Sip与WebRTC互通-SRProxy开源库讲解

SRProxy介绍目前WebRTC协议跟SIP协议互通场景主要运用在企业呼叫中心、企业内部通信、电话会议(PSTN)、智能门禁等场景,要想让WebRTC与SIP互通,要解决两个层面的...

全网第N篇SIP协议之GB28181注册 JAVA版本

鉴于网上大部分关于SIP注册服务器编写都是C/C++/python,故开此贴,JAVA实现也贴出分享GB28181定义了了基于SIP架构的视频监控互联规范,而对于多数私有协议实现的监控系统...

「linux专栏」top命令用法详解,再也不怕看不懂top了

在linux系统中,我们经常使用到的一个命令就是top,它主要是用来显示系统运行中所有的进程和进程对应资源的使用等信息,所有的用户都可以使用top命令。top命令内容量丰富,可令使用者头疼的是无法全部...

取消回复欢迎 发表评论:

请填写验证码