首页 > 编程语言 >java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别

时间:2023-02-20 13:01:25浏览次数:41  
标签:Map Set 区别 ArrayList List LinkList Vector 线程


系列文章目录

文章目录

  • ​​系列文章目录​​
  • ​​List、Set、Map三者的区别​​
  • ​​说出ArrayList、LinkList、Vector的区别​​
  • ​​用源码来佐证​​
  • ​​总结​​

List、Set、Map三者的区别

看图说明即可,

List和Set是同级的,他们都继承了 Collection

而Map则不一样,它与Collection是同级的

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别_线程安全

接着:

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别_List_02

说出ArrayList、LinkList、Vector的区别

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别_线程安全_03


Vector(是老的类,好像不能这么说),它是线程安全的,即是同步的

什么叫线程异步,就是不安全的,用到多线程的时候,可能就会有问题

主要看取舍,是对数据安全有要求还是对效率有要求

怎么选择呢?

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别_线程安全_04

1、做查询量较大的操作的时候使用ArrayList或者Vector,
如果程序中使用了多线程对线程安全要求的话使用Vector,否则使用ArrayList
2、如果是做插入量比较大的操作的时候,首选LinkList,插入效率高,但不适合查询

用源码来佐证

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别_多线程_05


加了这个就是同步的

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别_多线程_06


同样的我们去看ArrayList的add方法,看看有没有synchronized这个同步锁,有就是线程安全,没有就是线程不安全

java面试_集合框架001_List、Set、Map三者的区别_说出ArrayList、LinkList、Vector的区别_List_07

总结


标签:Map,Set,区别,ArrayList,List,LinkList,Vector,线程
From: https://blog.51cto.com/u_15800767/6068372

相关文章

  • 00022.08 Scanner的next()和nextLine()区别
    系列文章目录文章目录​​系列文章目录​​​​一、Scanner:​​​​二、使用步骤​​​​总结​​一、Scanner:Scanner:(1)next():遇到空白符就认为输入结束(2)nextLine():遇到换......
  • javaEE004.03 事件: window.onload与jQuery(fn)的区别
    window.onload与$(fn)的区别_目录文章目录​​window.onload与$(fn)的区别_目录​​​​一、事件​​​​window.onload与$(fnction(){})​​​​二、总结​​一、事件文档......
  • HashSet的使用以及存储方式
    packageedu.wtbu;importjava.util.HashSet;importjava.util.Iterator;publicclassDemo01{publicstaticvoidmain(String[]args){//HashSet:存储结......
  • YOLO [email protected][email protected]:0.95的含义
    [email protected][email protected]:0.95的含义[email protected]:meanAveragePrecision(IoU=0.5)即将IoU设为0.5时,计算每一类的所有图片的AP,然后所有类别求平均,即mAP如图所示,AP50,AP60,AP70……......
  • 指针和引用的区别
    指针是一个变量,存储的是一个地址,引用跟原来的变量实质上是同一个东西,是原变量的别名指针可以有多级,引用只有一级指针可以为空,引用不能为NULL且在定义时必须初始化指针......
  • Set接口的使用
    importjava.util.HashSet;importjava.util.Iterator;importjava.util.Set;publicclassDemo01{publicstaticvoidmain(String[]args){//Set接口:无......
  • Map
      介绍ES6提供了Map数据结构。它类似于对象,也是键值对的集合。但是“键的范围不限于字符串,各种类型的值(包括对象)都可以当作键。Map也实现了iterator接口......
  • 集合 Set方法
     set方法可以去重数组//声明一个setlete=newSet()letess=newSet(['张三','李四','王五','李四'])console.log(ess);......
  • Pycharm cannot set up a python SDK
    一、问题背景进入Pycharm后,打开之前的项目,打开Pycharm→file→settings→projectinterpreter,按照下图1选择配置之后,点击【OK】会出现报错,如图2我的环境上有很多之前的包......
  • 2.20 Q_Learning 和Sarsa 的区别
    二者都是基于Qtable的算法,其中Qlearning属于off-policy,Sarsa属于on-policy。算法伪代码:   二者主要区别是更新Qtable的方式不同:    ......