day18 集合框架(JCF)

集合框架(JCF)java collections framework

框架:为了实现某一目的/功能而预先提供的一系列封装好的具有继承或实现关系的类与接口。

1、这种框架是高性能的,对基本类集(动态数组、链接表、树、散列表)的实现是高效率的。

2、框架必须允许不同的类集以相同的方式和高度互相操作方式工作。

3、类集必须是容易扩展和修改的。

为了实现这些目标,类集框架被设计成包含了一组标准接口的类与接口:

Collection 是存放一组单值的最大接口。

List——列表

是Collection的子接口,里面的内容允许重复。

List的特点:线性。即:有序。元素放入的顺序和元素的存储顺序保持一致。

表象上:List最大的特点就是有下标。

ArrayList: 就是作为一个数组的封装出现的,底层就是数组。

LinkedList:底层封装的是一个双向链表。

1、查找、修改用的多的时候用ArrayList。

2、增加、删除用的多的时候(特别是往中间增加、删除)用LinkedList。

3、线程安全,数据量大的时候考虑用vector。

泛型<>:用来控制集合只能操作某一种数据类型。

遍历:1、普通for循环遍历。

2、使用迭代器Iterator完成遍历。——没有下标从头到尾走一遍,不能操作数组。

3、for-each循环语句,底层封装的就是迭代器,语法简单,还可以操作数组。推荐使用。

Set——集

是collection的子接口,里面的内容不允许重复。

特点:不能放置重复元素,无序存放元素。

表象上:Set没有下标。

HashSet判断两元素不重复:1、调用equals方法比较两对象

2、两元素的hashcode值保持一致

只有这两个条件同时满足,java才认为是同一对象。

所有重写了equals方法一般要重写hashcode方法,让equals返回true的时候,hashcode返回的值应该一样。

hashSet只有增、删、求长度和遍历等操作。

遍历:1、迭代器

2、for-each

Map——映射

是存放一对值的最大接口,所有的元素都以键和值的方式存储。

特点:键值对——键要求唯一,值可以重复

常用子类:hashMap、properties(专用于操作属性文件)

hashMap

常用操作:增、删、改、查、容、遍历

遍历的时候:不能同时遍历所有的键和值,只能单独遍历键与值。

键在遍历的时候用Set类型来接。

值在遍历的时候用Collection来接。

hashMap与hashTable比较:1、hashMap非线性安全,hashTable是线性安全的。

2、hashMap允许null来做键/值,hashTable不允许。

properties

常用操作:增、删、查、改、容、存、取。

存的时候,调用的是.store方法存文件,

取的时候,调用.load方法取文件。

文件类型:.properties——固定格式的文本文件,将是工作中使用率第二的配置文件。

Iterator

集合的输出接口,从前到后输出指定集合中的内容。

ListIterator

是Iterator的子接口,可以进行双向输出。

Enumeration

是最早的输出接口,用于输出指定集合中的内容。

collections

集合操作的算法类

包括排序、求最大、最小、反转、随机混排等操作

排序的时候,因为是对对象排序,所以应按一定的业务逻辑的自然顺序排序。

比较器:

comparable接口:内部比较器

可对任意数组排序,java泛型技术,二叉树排序原理

1、类实现comparable接口

2、重写compareTo方法

compareTo方法返回的是int类型数据:1表示大于,-1表示小于,0表示相等。

comparator接口:外部比较器

补救的做法

此接口一样需要重写方法,但方法接收两个对象,返回值依然是1、-1、0;

SortedSet

单值的排序接口,实现此接口的集合类,里面的内容可以使用比较器排序。

SortedMap

存放一对值的排序接口,里面内容按照key排序,使用比较器排序。

Queue

队列接口,此接口的子类可以实现队列操作。

Map.Entry

Map.Entry的内部接口,每个

Map.Entry对象都保存着一对key——value的内容,每个map接口中都保存有多个Map.Entry接口实例。

总的来说:

1、如果要求线程安全,使用Vector、Hashtable。

2、如果不要求线程安全,使用ArrayList(查找、修改较多的时候使用)、LinkedList(删除、增加较多的时候使用)、HashMap(要求键值对映的时候使用)。

3、如果要求键值对应,使用HashMap、HashTable。

4、如果数据量大、又要求线程安全考虑使用Vector。

时间: 2024-11-02 01:20:36

day18 集合框架(JCF)的相关文章

day18&lt;集合框架+&gt;

集合框架(Map集合概述和特点) 集合框架(Map集合的功能概述) 集合框架(Map集合的遍历之键找值) 集合框架(Map集合的遍历之键值对对象找键和值) 集合框架(Map集合的遍历之键值对对象找键和值源码分析) 集合框架(HashMap集合键是Student值是String的案例) 集合框架(LinkedHashMap的概述和使用) 集合框架(TreeMap集合键是Student值是String的案例) 集合框架(统计字符串中每个字符出现的次数) 集合框架(集合嵌套之HashMap嵌套Hash

Java集合框架(JCF)之collention

一.概念:是为了实现某一目的或功能而预先提供的一系列封装好了的具有继承或实现的类与接口. 二.特点: 1.元素的类型可以不同  2.集合长度可变 3.空间不固定 三.collection与collections的比较 1.collection是封装东西的核心接口, 2.collections是操作集合的一个算法类. 四.collection接口下包括有(list.set.map)三种集合: 1.list集合(包含Arraylist.linkedlist.vector)------>列表 ①特点:

Java 集合系列之一:JCF集合框架概述

容器,就是可以容纳其他Java对象的对象.Java Collections Framework(JCF)为Java开发者提供了通用的容器 java集合主要划分为四个部分: Collection(List列表.Set集合).Map映射.迭代器(Iterator.Enumeration).工具类(Arrays.Collections) 背景 数组的优势:是一种简单的线性序列,可以快速地访问数组元素,效率高.如果从效率和类型检查的角度讲,数组是最好的.数组的劣势:不灵活.容量需要事先定义好,不能随着需

JAVA——Java集合框架

1. 什么是框架:类库的集合 2.集合框架:用来表示和操作的统一的架构,包含了实现集合的接口与类 3.集合:存放数据的容器 集合框架包含了两部分:一部分是接口,一部分是类 4.为什么会出现接口:因为集合框架中的很多类 功能是相似的[所以用接口来规范类] Java  SE包含了由一组类和接口组成的Java集合框架(JCF),其主要功能是用来将存储的数据以某种结构组织,并以特定的方式来访问. Set接口的3种实现: HashSet的对象必须实现hashCode方法,javaAPI大多数类实现了has

Java 集合框架初步

Java 集合框架 JCF(Java Collections Framework) Collections Collection提供关于集合的一些通用操作的接口 包括: 插入add() 删除remove() 判断一个元素是不是其成员contains 遍历iterator() List--有序集合 Set--无序集合,不予许存在重复值 Map--映射 集合初步 熟悉使用ArrayList 开始学会使用jdk的api文档 ArrayList----List接口的一个实现 有序,允许存在重复值 imp

Java集合框架介绍。Java Collection Frameworks = JCF

Java集合框架 = Java Collection Frameworks  = JCF . 为了方便理解,我画了一张思维脑图.

《JAVA集合框架(JCF)》

Java SE 包含了由一组类和接口组成的Java集合框架(Java Collection Framework,简称JCF),其主要功能是用来将存储的数据以某种结构组织,并以特定的方式来访问这些数据,其目标是提供一个处理对象集合的通用框架,减少程序员处理不同的对象集合时的编码量,而Java集合类都位于java.util包中. 接下来就简单的谈下JCF类的内容.首先Java集合框架将对象的存储方式分为三种类型,分别是:Set(集).List(列表).Map(映射). Set(集):对象容器中的对象

Java 之 集合框架(JCF)

1.集合框架 a.框架:为了实现某一目的或功能,而预先提供的一系列封装好的.具有继承或实现关系的类与集合 b.集合:①定义:Java中对一些数据结构和算法进行封装,即封装(集合也是一种对象) ②特点:元素类型可以不同,集合长度可变,空间不固定 c.集合框架:提供了管理集合的接口和类 2.Collection 与 Collections a.Collection:是一个接口,装东西的集合接口 (核心接口) b.Collections:是一个算法类,操作即可的算法类 3.Collection Col

《深入理解Java集合框架》系列文章

Introduction 关于C++标准模板库(Standard Template Library, STL)的书籍和资料有很多,关于Java集合框架(Java Collections Framework, JCF)的资料却很少,甚至很难找到一本专门介绍它的书籍,这给Java学习者们带来不小的麻烦.我深深的不解其中的原因.虽然JCF设计参考了STL,但其定位不是Java版的STL,而是要实现一个精简紧凑的容器框架,对STL的介绍自然不能替代对JCF的介绍. 本系列文章主要从数据结构和算法层面分析