一、Java 中的集合类

  1、集合概述

    Java中集合类是用来存放对象的
      集合相当于一个容器,里面包容着一组对象 —— 容器类
      其中的每个对象作为集合的一个元素出现
      Java API提供的集合类位于java.util包内

  2、Java 中数组与集合的比较

    数组也是容器,它是定长的,访问较快,但是数组不会自动扩充
    数组可以包含基本数据类型或引用类型的对象,而集合中只能包含引用类型的对象

  3、Java 中集合框架层次结构

二、Colleciton 接口

  1、一组称为元素的对象
  2、一个Collection中可以放不同类型的数据
  3、是Set接口和List接口的父类
  4、是否有特定的顺序以及是否允许重复,取决于它的实现
  5、Set - 无序的集合;不允许重复 HashSet
  6、List - 有序的集合;允许重复
    ArrayList、
    LinkedList

  1、Collection 接口

  2、Set 接口

    (1)Collection的子接口
    (2)用来包含一组 无序无重复 的对象
      无序 — 是指元素存入顺序和集合内存储的顺序不同
      无重复 — 两个对象e1和e2,如果e1.equals(e2)返回true,则认为e1和e2重复

  3、Set 接口的实现类

    HashSet — HashSet的特性在于其内部对象的散列存取,即采用哈希技术
    TreeSet — TreeSet存入的顺序跟存储的顺序不同,但是存储是按照排序存储的

  4、List 接口

    Collection的子接口
      用来包含一组 有序有重复 的对象
      List中的元素都对应一个整数型的序号,记载其在容器中的位置,可以根据序号存取容器中的元素
      List有两种主要的集合实现类:
        ArrayList
        LinkedList

  5、List 接口的实现类

    1、ArrayList是线性顺序存储的,是一种线性表
    1、它的特性和数组很接近,数组大小是不变的,而ArrayList的大小是可以动态改变的

    3、是数据结构中链表的java实现
    4、相对于List来说,LinkedList最主要的功能方面的增强是可以在
      List的头部和尾部添加、删除、取得元素,直接提供了这些方法的实现。所以它可以非常方便的实现我们数据结构中的常见的
      Stack(栈)、queue(队列)等

    5、ArrayList 与 LinkedList的比较

      存储结构
        ArrayList是线性顺序存储
        LinkedList对象间彼此串连起来的一个链表
      操作性能
        ArrayList适合随机查询的场合
        LinkedList元素的插入和删除操作性高
      从功能上,LinkedList要多一些

  6、Iterator 接口

    1、Iterator对象称作迭代器,用来方便的实现对容器内的元素进行遍历操作
    2、所有实现了Collection接口的集合类都有一个iterator( )方法,返回一个实现了Iterator接口的对象
    3、Iterator对象实现了统一的一个用来遍历Collection中对象的方法
    4、Iterator是为遍历而设计,能够从集合中取出元素和删除元素,但是没有添加元素的
功能
    5、Iterator的功能上比较简单,使用中,只能单向移动

    6、 Iterator 接口

三、Collections 类

  Collections类是类似于Arrays类的公用工具类 ,它提供了一些static方法供集合类使用或操作集合类 。

  Collections 类中的方法

四、Map 接口

  Map内存储的是键/值对这样以成对的对象组(可以把一组对象当成一个元素),通过“键”对象来查询“值”对象

  Map是不同于Collection的另外一种集合接口
  Map中,key值是唯一的(不能重复),而key对象是与value对象关联在一起的
  Map接口有两个实现:
    HashMap — key/value对是按照Hash算法存储的
    TreeMap — key/value对是排序(按key排序)存储的

   1、Map 接口

  2、Map 接口的实现类

    基于哈希表的 Map 接口的实现

    HashMap的构造方法

      HashMap 变量名 = new HashMap() ;
      HashMap 变量名 = new HashMap(int capacity) ;
      HashMap 变量名 = new HashMap(int capacity,float lodeFactor) ;
      HashMap 变量名 = new HashMap(Map m) ;

  3、HashMap 与 TreeMap 的比较

    Hashtable是基于陈旧的Dictionary类的,HashMap是Java 1.2引进的Map接口的一个实现。
    Hashtable是线程安全的,也就是说是同步的,而HashMap是线程序不安全的,不是同步的。
    HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。

五、集合类的选择

  使用集合类时常见的异常

六、泛型的使用

  1、集合在使用上的问题

    集合中的add( )方法接受的是一个Object对象的参数 ,在获取集合中的对象时,必须进行造型(强制类型转换)操作。
    造型操作可能出现问题,一般在程序运行时才能发生,发现问题比较困难。
  2、集合中泛型的使用
    在对象放入集合前,为其作个限制
    在获取集合中的对象时,不用进行造型的操作
    当有不同类型的对象添加到集合中的时候,编译时就能检查出错误

    泛型经常被称为参数化类型,它能够像方法一样接受不同类型的参数。

    定义方式
      ArrayList<E> 变量名 ;

    E是变量类型
      ArrayList<String> arr;
      arr = new ArrayList<String>();
      HashMap<Integer,String> hm = new HashMap<Integer,String>();

Java 高级应用编程 第二章 集合的更多相关文章

  1. Professional.WebGL.Programming-Chapter 2(高级WebGL编程——第二章)

    (目前发现一些文章被盗用的情况,我们将在每篇文章前面添加原文地址,本文源地址:http://www.cnblogs.com/idealer3d/p/3508251.html) 这一章主要通过创建一个三 ...

  2. Java 高级应用编程 第一章 工具类

    一.Java API Java API简介 1.API (Application Programming Interface) 应用程序接口 2.Java中的API,就是JDK提供的各种功能的Java ...

  3. 《JavaScript高级程序设计》——第二章在HTML使用JavaScript

    这章讲的是JavaScript在HTML中的使用,也就是<script>元素的属性.书中详细讲了async.defer.src和type四个<script>的属性. 下面是对第 ...

  4. java面向对象编程——第二章 java基础语法

    第二章 java基础语法 1. java关键字 abstract boolean break byte case catch char class const continue default do ...

  5. [转]Windows Shell 编程 第二章 【来源:http://blog.csdn.net/wangqiulin123456/article/details/7987893】

    第二章Shell的结构  “Shell 编程”的大伞之下有大量的API函数和COM接口.这个种类繁多的‘命令’集允许你用不同的方法对Windows Shell进行编程.函数和接口并不是两种提供相同功能 ...

  6. 使用MYSQL数据库实现编程----第二章第三章课堂知识小总结

    第二章1:创建数据库create database myschool 2.数据类型  1.整型 int  2.小数 double  精确度要求高的 ----Decimal(18,4)  2222222 ...

  7. 《深入理解Java虚拟机》笔记--第二章、Java内存区域与内存溢出异常

    Java程序员把内存的控制权交给了Java虚拟机.在Java虚拟机内存管理机制的帮助下,程序员不再需要为每一个new操作写对应的delete/free代码,而且不容易出现内存泄露和溢出. 虚拟机在执行 ...

  8. Java面向对象编程 第二章 第一个Java应用

    2.1创建Java源文件 Java应用由一个或多个扩展名为".java"的文件构成,这些文件被称为Java源文件,从编译的角度,则被称为编译单元. 本章包含两个Java源文件:Do ...

  9. JAVA / MySql 编程——第二章 初始MySQL

    1. MySQL:        ●  MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司.            MySQL最流行的关系型数据库管理系统, ...

随机推荐

  1. 【深入理解JAVA虚拟机】第5部分.高效并发.1.Java内存模型与线程。

    1.概述 摩尔定律:描述处理器晶体管数量与运行效率之间的发展关系.Amdahl定律:通过系统中并行化与串行化的比重来描述多处理器系统能获得的运算加速能力. 从摩尔定律到Amdahl定律的转变,代表了近 ...

  2. Future Research Directions in Social Recommendation

    From the tutorial published by Martin Ester in RecSys 2013 Future Research Directions --Recommendati ...

  3. apache log4j-1.2.15的使用

    1.这个log4j的下载 下载 http://www.apache.org/dyn/closer.cgi/logging/log4j/1.2.15/apache-log4j-1.2.15.zip 2. ...

  4. (fields.E130) DecimalFields must define a 'decimal_places' attribute.

    DecimalField类型:固定精度的十进制数,一般用来存金额相关的数据.额外的参数包括DecimalField.max_digits(整个数字的长度)和DecimalField.decimal_p ...

  5. 静态路由解决双外卡,PC做路由器的实现

    1,曾经医院,有两个网卡,一个内,一个外,但都有网关(192.168.1.246. 192. 168.6.1) 这样同一时候开启就会出现网络不通. 当时并没有细究原因. 这次医院信息化项目上马,我学到 ...

  6. git及github配置入门

    github是一个有海量开源代码库的网站,同时也是一个软件开发管理软件,作为软件来说它集成了git这个分布式的版本控制系统,可以上传.下载和管理自己的代码. 笔者刚接触不久,把认为入门应该知道的东西稍 ...

  7. mysql5.7.22tar包安装

    mysql5.7.22tar包安装 #卸载系统自带的Mariadb [root@ ~]# rpm -qa|grep mariadb mariadb-libs-5.5.44-2.el7.centos.x ...

  8. 【洛谷P1982】小朋友的数字

    小朋友的数字 题目链接 题目翻译: 每个小朋友有一个数字,构成一个数字序列a1,a2…an 我们定义“特征值”fi为a1~ai中的最大连续子段和 再定义“分数”si为1~i-1中最大的(sj+fj), ...

  9. TestNG注解使用技巧 - @Factory

    之前在测试中一直使用testNG的@Test注解都很顺利没有碰到什么问题,今天突然遇到@Test不能用的情况,运行后提示: org.testng.TestNGException: Can't invo ...

  10. 跨浏览器的事件对象EventUtil

    var EventUtil = function(){ /*--addHandler--*/ addHandler:function(element,type,handler){ if(element ...