集合类概述

1.继承树



2.集合和数组

区别如下:

  • 数组可以存储基本数据类型,也可以存储引用类型;而集合只能存储引用类型(比如存储int,它会自动装箱成Integer)
  • 数组长度固定,集合长度可变

3.List和map

  • 相同

    • 都是集合类,都是接口
  • 区别
    • List存储单列元素,Map存储键值对
    • List允许元素重复,Map不允许key重复(重复则覆盖)
    • List存储有序,Map存储无序
  • 无论是List还是Map,它们实现动态增长都是有性能消耗的。在初始化集合的时候先估算数据量并分配合理的容量会减少动态增长时的消耗。

4.Collection基础功能

Collection接口定义的操作集合的方法有:

  • int size()
  • boolean add(Object o)
  • boolean addAll(Collection c)
  • void clear()
  • boolean contains(Object o)
  • boolean containsAll(Object o)
  • Iterator iterator()
  • boolean isEmpty()
  • boolean remove(Object o)
  • boolean removeAll(Collection c)
  • boolean retainAll(Collection c)
  • Object[] toArray()

集合遍历

1.forEach方法

Java8为Iterator接口新增的forEach默认方法

    import java.util.Collection;
import java.util.HashSet; public class CollectionTest {
public void each() {
Collection<String> books = new HashSet<>();
books.add("aaaaaa");
books.add("bbbbbb"); //1.使用Collection提供的方法
books.forEach(str -> System.out.println(str));

2.使用迭代器Iterator

每个集合都以内部类的方式实现了Iterator接口,Iterator替代了Enumeration,其更加安全,因为其遍历集合时会阻止其他线程修改集合

ListIterator继承了Iterator接口,它用于遍历List集合的元素,由于是双向遍历,不仅可以删除元素,还可以添加和修改元素

Java8增强的Iterator提供的方法如下:

  • boolean hasNext()

  • Object next()

  • void remove()

  • void forEachRemaining(Consumer action)

    	//2使用iterator的方法
    Iterator<String> iterator = books.iterator();
    while (iterator.hasNext()) {
    //需要强制转换
    String str = (String) iterator.next();
    if("aaaaaa".equals(str))
    iterator.remove();
    } //3.使用lambda表达式遍历
    iterator.forEachRemaining(str -> System.out.println(str));
    }
    }

集合过滤

  1. Java8为Collection新增的removeIf(Predicate filter)方法,可以批量删除符合filter条件的元素。使用lambda表达式做参数表述为books.removeIf(str -> ((String)str).length() < 10);
  2. 使用Java8新增的Stream流来操作集合
    • 包含Stream、InStream、LongStream、DoubleStream等流式API,独立使用步骤如下:
	public void stream() {
//1.使用流的builder类方法创建对应的Builder
//2.重复调用add()方法向流中添加元素
//3.调用builder的build()方法获取对应的Stream
IntStream is = IntStream.builder()
.add(1)
.add(2)
.add(3)
.add(5)
.build();
//4.调用Stream的聚集方法(很多),每次只能调用一个,调用完流即不可用
//如System.out.println(is.sum()); //将is映射成新的newIs流
IntStream newIs = is.map(ele -> ele * 2 + 1);
//使用方法引用的方式遍历集合元素
newIs.forEach(System.out::println);
}
- 使用Collection接口提供的stream()默认方法,返回对应集合的流,进而进行聚集操作,简化了集合编程。使用如下:
	public void preStream() {
Collection<String> books = new HashSet<>();
books.add("java");
books.add("myjava");
books.add("JAVA");
System.out.println(books.stream().filter(ele -> ((String)ele).contains("java")).count()); //1.先调用Collection对象的stream方法将集合转换为Stream
//2.再调用Stream的mapToInt方法获取原有的Stream对应的IntStream
//3.再调用forEach方法遍历IntStream中的元素
books.stream().mapToInt(ele -> ((String)ele).length()).forEach(System.out::println);
}

fail-fast机制

  1. 简介

    fail-fast机制是java容器(Collection和Map都存在fail-fast机制)中的一种错误机制。在遍历一个容器对象时,当容器结构被修改(remove方法除外),很有可能会抛出ConcurrentModificationException,产生fail-fast。
  2. 原理

    每次初始化一个迭代器都会执行int expectedModCount = modCount;,modCount表示修改次数,迭代器会通过checkForComodification()方法判断modCount和expectedModCount 是否相等,如果不相等就表示已经有线程修改了集合结构。
  3. 如何避免

    使用java.util.concurrent包下的类去取代java.util包下的类。Java1.5并发包含有线程安全集合类,允许在迭代时修改集合,比如ConcurrentHashMap。

集合00_Java集合框架的更多相关文章

  1. Java集合-----java集合框架常见问题

    1什么是Java集合API Java集合框架API是用来表示和操作集合的统一框架,它包含接口.实现类.以及帮助程序员完成一些编程的算法. 简言之,API在上层完成以下几件事: ● 编程更加省力,提高城 ...

  2. 集合_java集合框架

    转载自http://blog.csdn.net/zsw101259/article/details/7570033 Java集合框架图 简化图: Java平台提供了一个全新的集合框架.“集合框架”主要 ...

  3. Java 集合学习--集合概述

    一.集合框架 集合,通常也叫容器,java中有多种方式保存对象,集合是java保存对象(对象的引用)的方式之一,之前学习的数组是保存对象的最有效的方式,但是数组却存在一个缺陷,数组的大小是固定的,但是 ...

  4. 【BZOJ-4199】品酒大会 后缀数组 + 并查集合并集合

    4199: [Noi2015]品酒大会 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 436  Solved: 243[Submit][Status] ...

  5. Linq to 泛型集合查询集合包括大写M和年龄小于等于18

    #region Linq to 泛型集合查询集合包括大写M和年龄小于等于18            //List<Student> list = new List<Student&g ...

  6. IT第二十一天 - Collections、ArrayList集合、LinkedList集合、Set集合、HashMap集合、集合的操作注意【修20130828】

    NIIT第二十一天 上午 集合 1. 集合Collection存储数据的形式是单个存储的,而Map存储是按照键值对来存储的,键值对:即键+值同时存储的,类似align="center&quo ...

  7. 数组转集合、集合转数组、字符串数组与int型、long型数组等的转换

    在项目中经常会遇到数组转集合.集合转数组.数组之间类型转换等操作 1.数组转集合 为了实现把一个数组转换成一个ArrayList,很多Java程序员会使用如下的代码: String str[] = { ...

  8. 廖雪峰Java5集合-1Java集合简介-1Java结合简介

    1.集合 定义:集合就是一堆东西.集合里的东西,称为元素Element 数学中的集合: 有限集合: * 一个班所有的学生组成的集合 * 一个网站所有的商品组成的集合 无限集合: * 全体自然数集合 * ...

  9. Java集合 -- ArrayList集合及应用

    JAVA集合 对象数组 集合类之ArrayList 学生管理系统 斗地主案例 NO.one 对象数组 1.1 对象数组描述 A:基本类型的数组:存储的元素为基本类型 int[] arr={1,2,3, ...

随机推荐

  1. Day6 模块及Python常用模块

    模块概述 定义:模块,用一砣代码实现了某类功能的代码集合. 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,提供了代码的重用性.在Python中,一个.py文件就称之为一个模块(Mod ...

  2. aic bic mdl

    https://blog.csdn.net/xianlingmao/article/details/7891277 https://blog.csdn.net/lfdanding/article/de ...

  3. CSS小知识-----前缀-moz-、-ms-、-webkit-,-o-分别代表的意思

    这种方式在业界上统称:识别码.前缀 -ms-代表[ie]内核识别码 -moz-代表火狐[firefox]内核识别码 -webkit-代表谷歌[chrome]/苹果[safari]内核识别码 -o-代表 ...

  4. [博客迁移]探索Windows Azure 监控和自动伸缩系列2 - 获取虚拟机的监控定义和监控数据

    上一篇博文介绍了如何连接Windows Azure: http://www.cnblogs.com/teld/p/5113063.html 本篇我们继续上次的示例代码,获取虚拟机的监控定义和监控数据. ...

  5. Spark学习之路 (十五)SparkCore的源码解读(一)启动脚本

    一.启动脚本分析 独立部署模式下,主要由master和slaves组成,master可以利用zk实现高可用性,其driver,work,app等信息可以持久化到zk上:slaves由一台至多台主机构成 ...

  6. ubuntu 换源过程中遇到的坑(一):Could not resolve 'mirrors.aliyun.com'

    执行更新数据(sudo apt-get update)提示: Err http://mirrors.aliyun.com trusty Release.gpg Could not resolve 'm ...

  7. XML文件怎么添加注释

    注释以 <!-- 开始并以 --> 结束,例如 <!--注释内容-->.   注释可以出现在文档序言中,包括文档类型定义 (DTD):文档之后:或文本内容中. 注释不能出现在属 ...

  8. 什么是ASCII

    以下内容是从百度百科学的 1)ASCII(American Standard Code for Information Interchange:美国信息交换标准代码) 2)产生原因 在计算机中,所有的 ...

  9. sql server 中后缀为.mdf的文件是干什么用的??

    在微软的SQL Server 2000 数据库有三种类型的文件: 1)主要数据文件(扩展名.mdf是 primary data file 的缩写) 主要数据文件包含数据库的启动信息,并指向数据库中的其 ...

  10. Impala 学习

    Impala 基础知识介绍与学习,参考文章: Impala-大数据时代快速SQL引擎 https://blog.csdn.net/kangkangwanwan/article/details/7865 ...