总结一下学过的java容器知识。

一、java容器框架

由于之前学习的java容器类比较混乱,先简单的整理一下java集合框架。

首先,像这种图,网上到处都是,因为这个也算比较准确吧,我也懒得自己画了,因为我觉得这个目前对我来说不重要,这么多东西,并不是都用得到,其实日常写代码就只用到过几种,像最常用的ArrayList、HashMap等,在这里我只总结一些最基础的、常用的,希望对java初学者有所帮助。常用的java容器主要分为两大类:用于单值存储的Collection和用于双值存储的Map。这两个java容器类的最基础接口,那么我们主要用到的他们的哪些实现呢?

二、Collection接口

1,Collection接口是java集合类的基础接口。

collection主要方法:

  1. boolean add(Object o)添加对象到集合
  2. boolean remove(Object o)删除指定的对象
  3. int size()返回当前集合中元素的数量
  4. boolean contains(Object o)查找集合中是否有指定的对象
  5. boolean isEmpty()判断集合是否为空
  6. Iterator iterator()返回一个迭代器
  7. void clear()删除集合中所有元素
  8. boolean containsAll(Collection c)查找集合中是否有集合c中的元素
  9. boolean addAll(Collection c)将集合c中所有的元素添加给该集合
  10. void removeAll(Collection c)从集合中删除c集合中也有的元素
  11. void retainAll(Collection c)从集合中删除集合c中不包含的元素

前7个方法都是比较常用的,Collection接口又有常用的两个子接口,List接口和Set接口。

2,List接口中的元素是有序可重复的。

List接口有三个实现类:ArrayList,LinkList,Vector。

ArrayList是基于数组接口的集合类,所以数据的查询比较快,LinkList底层是双向链表实现的,所以增删比较快。Vector和特们的不同之处是Vector是线程安全的,效率也比较低,不太常用,在java的集合类中有一个很奇怪的现象,就是往往很多线程安全的东西,都不会经常用到,人们更喜欢把线程不安全的东西用一些特殊的方法使他变得线程安全,具体什么原因,在网上也查不到,还是要加紧学习啊!

3,Set接口中的元素是不可重复的。

Set接口有两个常用的实现类:HashSet,TreeSet。

HashSet是用的最多的,TreeSet用的则比较少,前者存储的元素是无序的(基于哈希表实现),后者存储的元素是有序的(基于二叉树)。两者都是线程不安全的。

三、Map接口

1,Map接口是java双值存储的最基础接口

Map主要方法:

2,HashMap

3,HashTable

4,TreeMap

四、补充

1,重复问题

2,排序问题

3,java数据接口

https://study.163.com/course/courseMain.htm?courseId=1006190095

五、总结

实现类/特性 线程安全 存取速度 数据结构 使用频率 迭代方法
ArrayList          
LinkList          
Vector          
HashSet          
TreeSet          
HashMap          
HashTable          

java容器基础的更多相关文章

  1. 工作随笔—Java容器基础知识分享(持有对象)

    1. 概述 通常,程序总是运行时才知道的根据某些条件去创建新对象.在此之前,不会知道所需对象的数量,甚至不知道确切的类型,为解决这个普遍的编程问题:需要在任意时刻和任意位置创建任意数量的对象,所以,就 ...

  2. Java容器基础概况

    一.什么是Java容器 书写程序时,我们常常需要对大量的对象引用进行管理.为了实现有效的归类管理,我们常常将同类的引用放置在同一个数据容器中.Java容器类是java提供的工具包,包含了常用的数据结构 ...

  3. Java容器之旅:容器基础知识总结

    下图展示了Java容器类库的完备图,包括抽象类和遗留构件(不包括Queue的实现). 常用的容器用黑色粗线框表示,点线框表示接口,虚线框表示抽象类,实线框表示类,空心箭头表示实现关系.Produce表 ...

  4. 【Java心得总结七】Java容器下——Map

    我将容器类库自己平时编程及看书的感受总结成了三篇博文,前两篇分别是:[Java心得总结五]Java容器上——容器初探和[Java心得总结六]Java容器中——Collection,第一篇从宏观整体的角 ...

  5. 【Java心得总结六】Java容器中——Collection

    在[Java心得总结五]Java容器上——容器初探这篇博文中,我对Java容器类库从一个整体的偏向于宏观的角度初步认识了Java容器类库.而在这篇博文中,我想着重对容器类库中的Collection容器 ...

  6. 【Java心得总结五】Java容器上——容器初探

    在数学中我们有集合的概念,所谓的一个集合,就是将数个对象归类而分成为一个或数个形态各异的大小整体. 一般来讲,集合是具有某种特性的事物的整体,或是一些确认对象的汇集.构成集合的事物或对象称作元素或是成 ...

  7. Java以基础类库

    Java以基础类库JFC(Java Foundation Class)的形式为程序员提供编程接口API,类库中的类按照用途归属于不同的包中. (一)java.lang包 Java最常用的包都属于该包, ...

  8. java容器---集合总结

    思考为什么要引入容器这个概念? Java有多种方式保存对象(应该是对象的引用),例如使用数组时保存一组对象中的最有效的方式,如果你想保存一组基本类型的数据,也推荐使用这种方式,但大家知道数组是具有固定 ...

  9. 3)Java容器

    3)Java容器   Java的集合框架核心主要有三种:List.Set和Map.这里的 Collection.List.Set和Map都是接口(Interface). List lst = new ...

随机推荐

  1. Ubuntu 16.04 安装 Django==1.11.8

    vim  InStall-Django.sh #!/bin/bash rm -rf /usr/bin/python ln -s /usr/bin/python3 /usr/bin/python mkd ...

  2. anaconda下安装xgboost

    1.下载whl文件 网址:https://www.lfd.uci.edu/~gohlke/pythonlibs/#xgboost 选择合适自己的环境的下载,比如python3.6还是3.5的,64位机 ...

  3. 【模板】最大流模板(dinic)

    题目描述 如题,给出一个网络图,以及其源点和汇点,求出其网络最大流. 输入输出格式 输入格式: 第一行包含四个正整数N.M.S.T,分别表示点的个数.有向边的个数.源点序号.汇点序号. 接下来M行每行 ...

  4. 搞定PHP面试 - 函数知识点整理

    一.函数的定义 1. 函数的命名规则 函数名可以包含字母.数字.下划线,不能以数字开头. function Func_1(){ } //合法 function func1(){ } //合法 func ...

  5. 使用maven创建web项目时后面多出来Maven Webapp如何删除

    类似这样: 解决办法:

  6. ajax提交数据遇到400异常,原因及解决方案

    开发中遇到的问题, ajax的URL写的正确但是确无法正常跳转, 开发者模式下显示请求400异常. 前后台代码如下 ------------------------------------------ ...

  7. RobotFrameWork+APPIUM实现对安卓APK的自动化测试----第一篇【安装】

    文章来源http://blog.csdn.net/deadgrape/article/details/50563119 前言:关于RobotFrameWork+APPIUM实现对安卓APK的自动化测试 ...

  8. Sping面试题分析

    1.开放中主要使用Spring的什么技术? (1)IOC容器管理各层的组件 (2) 使用AOP配置声明式事务 (3)整合其他框架 2简述AOP和IOC概念 AOP : Aspect  Orienten ...

  9. CSU 1541 There is No Alternative (最小生成树+枚举)

    题目链接:传送门 题意: 有n个点.m条边.要使n个点所有连起来且要花费最小.问有哪些边是必需要连的. 分析: 要使花费最小肯定是做最小生成树.可是题目要求哪些边是必需要用的.我们能够 这样思考,我们 ...

  10. unity3d 中动画的帧事件

    代码事件监听 using UnityEngine; using System.Collections; public class BoxEventScript : MonoBehaviour { vo ...