2:列表(List)

特点:

(1):有序的(插入的顺序有序),元素有索引值。

(2):同意反复。

set/get/listIterator/subList

ArrayList

特点:(1):底层数组方式实现。

     (2):元素是有序的。

(是指加入进去的元素有序,不是指对象之间的顺序)

     (3):不是线程同步的。

     (4):因为是用数组实现。查找比較快。

循环:

迭代器
For循环

双向迭代器

LinkedList

特点:(1):底层机制链表方式实现。

     (2):元素是有序的。(是指加入进去的元素有序,不是指对象之间的顺序)

     (3):不是线程同步的。

     (4):因为是用链表实现。因此增删改对象比較easy。

查找比較慢。

CopyOnWriteArrayList

特点:(1):底层机制数组方式实现。

     (2):元素是有序的。(是指加入进去的元素有序,不是指对象之间的顺序)

     (3):它是线程同步的。

     (4):因为是用数组实现。因此查找比較快。增删改比較慢。

List中的subList方法

subList也会出现高速失败异常。

解决方法:又一次用subList截取的集合视图构建一个新的List就可以。

List list = new ArrayList();

List list2 = list.subList(3,5);

list.removeAll(list2);

List list = new ArrayList();

List list2 = new ArrayList(list.subList(3,5));

list.removeAll(list2);

Stack(数据结构)

(1):有序的(插入的顺序有序)。元素有索引值。

(2):同意反复。

(3):数据先进后出。

3:映射(Map)

特点:

(1):键值对的数据对象。键不能反复。(键反复的话。后面加入的覆盖前面)

   一个键相应一个值。

HashMap

(1):底层以哈希算法实现

(2):同意一个NULL键。同意多个NULL值。

(3):无序

(4):不是线程同步。

LinkedHashMap

(1):底层以链表算法实现

(2):同意一个NULL键。同意多个NULL值。

(3):有序(加入的顺序有序)

(4):不是线程同步。

存值:put(key,value);

取值: value = get(key)

迭代Map

A:使用KeySet(返回全部键的集合,循环键的集合。取出每个键,再通过键取值)。

B:使用values(返回全部值的集合),仅仅能获取值(值能够反复,所以不能通过值获取键)

C:使用entrySet(返回键值对的集合)。

集合中的每个元素都是一个Map.entry实体对象。

4:队列(Queue)

特点:

(1):与Stack一样,队列是一种数据结构。先进先出的特点。

加入:offer

删除:remove

获取队列元素 poll

单向队列:Queue queue = new LinkedList();

双向队列:LinkedList queue = new LinkedList();//这样双向队列能够操作队首与队尾。

5:老的一些集合框架类

特点:

全部都是线程安全的。

Vector

特点:(1):底层数组方式实现。

     (2):元素是有序的。(是指加入进去的元素有序,不是指对象之间的顺序)
     (3):是线程同步的。
     (4):因为是用数组实现,查找比較快。

HashTable

(1):底层以哈希算法实现
(2):不同意NULL键,不同意NULL值。
(3):无序
(4):线程同步。

Enumeration

老的迭代器。

没有提供remove元素的方法。(因为老集合都是线程安全的).

集合的工具类:

Arrays:用于操作数组的工具类。

对于数组的排序。加入,查找。

Collections:用于操作集合的工具类。对于集合的排序,加入。查找,比較等。

集合之间的相互转换

数组转List

数组转SET

List转数组

Set转数组

List转SET

J2SE基础:10集合2的更多相关文章

  1. 『Python基础-10』字典

    # 『Python基础-10』字典 目录: 1.字典基本概念 2.字典键(key)的特性 3.字典的创建 4-7.字典的增删改查 8.遍历字典 1. 字典的基本概念 字典一种key - value 的 ...

  2. J2SE基础题

    J2SE基础 八种基本数据类型的大小,以及他们的封装类.(有的也说是9中基本数据类型,包括了void) 基本类型 大小(字节) 默认值 封装类 byte 1 (byte)0 Byte short 2 ...

  3. [.net 面向对象编程基础] (10) 类的成员(字段、属性、方法)

    [.net 面向对象编程基础] (10) 类的成员(字段.属性.方法) 前面定义的Person的类,里面的成员包括:字段.属性.方法.事件等,此外,前面说的嵌套类也是类的成员. a.类的成员为分:静态 ...

  4. 十. Python基础(10)--装饰器

    十. Python基础(10)--装饰器 1 ● 装饰器 A decorator is a function that take a function as an argument and retur ...

  5. java基础-Map集合

    java基础-Map集合 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Map集合概述 我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它 ...

  6. JavaScript基础笔记集合(转)

    JavaScript基础笔记集合   JavaScript基础笔记集合   js简介 js是脚本语言.浏览器是逐行的读取代码,而传统编程会在执行前进行编译   js存放的位置 html脚本必须放在&l ...

  7. 万门大学Python零基础10天进阶班视频教程

    点击了解更多Python课程>>> 万门大学Python零基础10天进阶班视频教程 课程简介: 旨在通过两周的学习,让学生不仅能掌握python编程基础从而进行计算机程序的开发, 还 ...

  8. 第6节:Java基础 - 三大集合(上)

    第6节:Java基础 - 三大集合(上) 本小节是Java基础篇章的第四小节,主要介绍Java中的常用集合知识点,涉及到的内容包括Java中的三大集合的引出,以及HashMap,Hashtable和C ...

  9. Java基础之 集合体系结构(Collection、List、ArrayList、LinkedList、Vector)

    Java基础之 集合体系结构详细笔记(Collection.List.ArrayList.LinkedList.Vector) 集合是JavaSE的重要组成部分,其与数据结构的知识密切相联,集合体系就 ...

随机推荐

  1. reportlab使用示例:文字和图片

    Python的reportlab专门将数据使用生成PDF中的图形和文档功能, 下载ReportLab https://pypi.python.org/simple/reportlab/ http:// ...

  2. shp系列(五)——利用C++进行shp文件的写(创建)

    之前介绍了shp文件.dbf文件和shx文件的的读取,接下来将分别介绍它们的创建过程.一般来说,读和写的一一对应的,写出的文件就是为了保存数据供以后读取的.写的文件要符合shapefile的标准.之前 ...

  3. golang图片压缩

    package main import (    //"encoding/json"    "fmt"    //"os"    //&qu ...

  4. PyQt5信号-槽机制

    signal -> emit -> slot signal.connect(slot) signal.disconnect(slot) 信号 (singal) 可以连接无数多个槽 (slo ...

  5. python基本数据类型之元祖tuple

    元祖tuple 是对列表的二次加工,书写格式为括号(),里面放元素 元组的一级元素不可被修改,且不能被增加和删除 一般写元组的时候,推荐在最后加入逗号,  能加则加 创建元组 ? 1 tu = (11 ...

  6. Android 自定义控件之圆形扩散View(DiffuseView)

    实现效果 使用 属性方法 代码 源码下载 参考链接 实现效果 使用 XML中: <com.airsaid.diffuseview.widget.DiffuseView android:id=&q ...

  7. Goldengate升级之目标端(replicat端)升级

    转自红黑联盟Goldengate升级之目标端(replicat端升级 要升级replicat端的原因为:目标端OGG软件版本与源端OGG软件版本不同,在实际生产应用中,经常发现replicat端事务丢 ...

  8. 【Oracle】闪回技术

    1.闪回技术描述 2.数据库的准备: --undo表空间要设置成AUTO,设置合适的保存时间.undo表空间: SYS@ENMOEDU> show parameter undo NAME TYP ...

  9. 初步学习Axure---整理了一下自己两周的学习成果:动态面板

    自己无意间发现了做原型设计的工具--Axure,所以就自学了一点皮毛.最近时间比较充裕,就把自己现学现卖的东西整一整. 作品比较简单,没有技术可言,根据用户和开发需求,利用动态面板和一些点击事件完成了 ...

  10. 团体程序设计天梯赛-练习集-L1-025. 正整数A+B

    L1-025. 正整数A+B 本题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000].稍微有点麻烦的是,输入并不保证是两个正整数. 输入格式: 输入在一行给出A和B,其间以空 ...