JAVA-初步认识-常用对象API(集合框架-List常用子类的特点)

一.

凡是虚线框都是接口,我们真正在使用的时候,用的是接口中的子类,

List接口中,有一堆子类,是我们开发中常用的容器。ArrayList,LinkList,Vecter这三个算是开发中比较常用的。

(list下面有三个常用的对象)

具体的容器必须明确其特点,那么你才知道什么时候该用这容器。

1. vector

容器之所以能够进行区分,是因为容器的内部的数据结构不一样,现在vector内部用的就是一个数组。数组本身就是一种存储数据的方式,本身就是一种结构。这种结构的特点在于,每一个元素上都带着编号,而且是连续地存储。一开辟空间,很多的小格子就出来了。

vetor从1.0版本就出现了,这个接口1.2才出来(vetor是早就有了,但是称为List接口的子类接口是从1.2开始的),

在1.0的时候,用的集合就一个vetor,到1.2才有的集合框架,才加了各种数据结构进来,产生了一个体系。1.2的时候也把vetor纳入进来了,vetor是元老级别的,它1.2才实现了list,具备了list功能,并成为java集合框架中的成员。vetor是同步的,也就是说线程是安全的。

2. ArrayList

内部也是数组结构,而且是可变的,是不同步的。为什么会有ArrayList的出现,因为vetor的同步效率低。结构是一样的,为什么要出现两个,因为替代了vetor。如果是多线程怎么办?就采用vetor?(不是),我们要么给ArrayList加锁,要么采用其他方式。vetor几乎不用了。怎么加锁呢?把那些添加删除的方法放到同一个锁里面就可以了。

ArrayList中提高了一个大小可变数组,vetor中也提到了可增长的对象数组。什么叫长度可变的数组?原先我们学习的时候,数组是固定长度,集合怎么实现不断地往里面加元素呢?可变长度数组原理,创建一个新数组,将原来数组中的内容都复制到新数组中来。

vetor是一定延长,ArrayList是有一半的机率延长。vetor是既浪费空间,也浪费效率,ArrayList会比vetor强一些。

3. linkedList

链接列表简称链表。

集合中,只要不是vetor,都是非同步的,因为效率高。

链表什么特点呢?数组怎么存储元素呢?将空间切割成多个小方格,然后将元素存储进去。怎么存储进去的呢?数组一开辟空间,都有角标,依据角标来存储元素。

链表是这样的:前一个元素的格子,记住下一个元素的角标值。

链表结构要是删除某一个元素,只需要记住下下个元素的角标值就可以了。

为什么要数据结构,就是对数据操作不一样,操作特点有所不同。链表这种结构删除元素的速度很快。

原文地址:https://www.cnblogs.com/wsw-bk/p/8157223.html

时间: 2024-10-08 23:45:14

JAVA-初步认识-常用对象API(集合框架-List常用子类的特点)的相关文章

JAVA-初步认识-常用对象API(集合框架-体系共性功能)

一. 集合是个容器,用来存储对象的.当我们存储的对象数目变多的时候,会带来一些问题. 对象在集合里面装的时候,到底是如何进行存储的?有人说直接往里扔就是了,要注意,对于对象而言,不止集合这么一种容器. 对于对象的存储方式,每一个集合都有自己独特的定义,是根据某些需求而定的. 举例子来谈:用水杯泡茶,必须有过滤网,不然喝茶会有茶叶,如果只是喝白开水那么就不需要过滤网. 这说明容器自身都有其特定的结构,这种结构我们称之为数据结构,容器里面存储的就是数据. 数据到底按照什么样的方式来进行存放呢?我们称

JAVA-初步认识-常用对象API(集合框架-ListIterator接口)

一. 把list往外取的动作也说一下,(有可能说的是从list中取出元素的动作). 从list中取出所有的元素,采用iterator,因为list属于Colletion的子类,Colletion中具备的东西list也都有.(上面的截图中list只是一个空的容器,然后不断地往里面添加元素,或者删减元素)返回了iterator是怎么理解? DOS结果没有任何问题. list有自己特有的元素取出方式,list.get(index),输入集合中的某一个角标值,打印出来的结果就是该角标上的元素. 如果是取

JAVA-初步认识-常用对象API(集合框架-迭代器使用)

一. 我们完善完集合框架顶层接口Collection中常见方法学习以后,准备把存储在Collection集合中的元素给它取出来,因为存的目的就是为了方便取出来使用元素.这个取得动作,Colection给我们提供了一个迭代器的方法(迭代器是一个专业术语,意为取出集合中元素的方式). 取出元素的方式是个方法完成的,现在来演示一下. new谁不重要,只要能new就可以(Collection接口的子类很多,挑选一个创建对象). 调用集合的迭代器方法,返回集合中的迭代器对象,那么返回的这个对象是什么类型?

JAVA-初步认识-常用对象API(集合框架-Map集合常见子类对象)

一. 说完了map集合,顺便说些小东西. map集合常用的子类: hashtable研究的就是数据结构,哈希在1.0就出来了,那是还没有table.当时,单列集合只有vector,双列集合就是hashtable.内部结构就是哈希表.是同步的.hashmap和hashtable有区别么,效率高低不再多说.下图是hashmap的API注解,是不同步的. hashtable,它不支持空键和空值.面试的时候它们之间的区别. 上面截图的体系和一个集合体系很像,就是set集合,hashset和treeset

JAVA-初步认识-常用对象API(集合框架-重点方法entryset演示图解)

一. 对于上一节的操作而言,这里还有另外一种做法,相对而言,有一点麻烦. 从刚才的动作,总结出一个原理.map集合没有迭代器,但是我们可以把map转换成有迭代器的集合,比如说set. 这是为什么呢?为什么不返回arrylist,这是拿所有的键,键是唯一的,所以返回的应该是set集合,保证元素的唯一性. 接下来,在API当中,还有一个方法也是返回set集合,(这里的set有什么特殊含义么?) 现在用它来完成取出所有元素的方式.keyset大家比较容易明白,里面装的都是键.但是,entryset是返

JAVA-初步认识-常用对象API(集合框架-泛型-泛型类)

一. 泛型我们了解完基本原理之后,除了在集合中用来传递参数类型外,还有其它的应用.它还能为我们提供很多设计上的便捷. 介绍一下以前和现在的定义方法,有什么不一样. 这里面为了方便于应用,搞了一个工具类,和主要的程序分开发. 对工具类的描述,现在要操作person,要用工具类对person对象进行操作,可以完成person对象的设置和获取. 这个工具类只能操作person,不能操作其它对象.如果想要其它对象,还要书写Tool1,Tool2......这样很麻烦,怎么办?(对传输进来的person对

JAVA-初步认识-常用对象API(集合框架-泛型-泛型限定-上限的体现)

一. 现在要说应用,查看一下API中的注释, 这里有一个方法addAll里面有extedns E,我们看一下这个方法什么时候用.下面这三个集合,有存储person,student,还有worker的. 再接下来演示一下这个高级应用,如果我们要去想定义一下集合的话,(描述一下集合) 这个类里面加入的元素不确定的情况下,写的是个E,明确什么类型,add方法中添加的也是什么类型.一次添加一个元素比较慢,addAll方法可以添加一堆元素, 一般情况下,就是这么写.(addAll又将mycollectio

JAVA-初步认识-常用对象API(集合框架-List集合的常用方法)

一. 现在重点学习一下List,List是Collection的子接口,那么Collection的方法,List都具备,共性方法就不讲述了. 讲述一下List中特有的方法,这些特有方法的共性就是可以对角标进行操作. (以下讲述的都是list中的方法,我觉着还是基于操作元素的角标) 1. 添加 截图中的第一个方法是父类Collection中的添加方法,第二个方法是自己特有的.给定一个角标位置,插入一个元素或者一堆元素. 上图中的方法是根据位置,拿元素.一旦有了角标,就可以精确进行定位了. 这里删除

JAVA-初步认识-常用对象API(集合框架-treeset集合-二叉树)

一. treeset集合可以对其中的元素进行排序,它有两种排序方法,现在我们想知道它底层是什么结构,它是怎么确定元素位置的?它是有原因的,而且它这种结构对于排序而言,效率很高. 一说到排序,之前说到选择冒泡.选择冒泡对于比较次数而言,比较多一些,因为是转着圈在比.对于treeset而言,有个比较好的地方就是 将例子中的元素按照年龄排序,演示一遍它是怎么存放的. 存zhangsan,28的时候,就在容器中搞了一个zhangsan,28.容器中只有一个元素,不进行比较.紧跟着再来个lisi,21,l