Java核心类库篇4——集合

Java核心类库篇4——集合

1、集合的意义

  • 记录单个数据内容时,则声明一个变量
  • 记录多个类型相同的数据内容时,声明一个一维数组
  • 记录多个类型不同的数据内容时,则创建一个对象
  • 记录多个类型相同的对象数据时,创建一个对象数组
  • 记录多个类型不同的对象数据时,则准备一个集合

2、集合的分类

  • 单列集合(Collection)
  • 双列集合(Map)

图片

3、Iterator接口

  • java.util.Iterator接口主要用于描述迭代器对象,可以遍历Collection集合中的所有元素
  • java.util.Collection接口继承Iterator接口,因此所有实现Collection接口的实现类都可以使用该迭 代器对象
方法声明功能介绍
public boolean hasNext()判断集合中是否有可以迭代/访问的元素
public E next()用于取出一个元素并指向下一个元素
public void remove()用于删除访问到的最后一个元素

4、Collection

4.1、方法

方法声明功能介绍
public boolean add(E e)向集合中添加对象
public boolean addAll(Collection c)将参数指定集合c中的所有元素添加到当前集合
public boolean contains(Object o)判断是否包含指定对象
public boolean containsAll(Collection c)判断是否包含参数指定的所有对象
public boolean retainAll(Collection c)保留当前集合中存在且参数集合中存在的所有对象
public boolean remove(Object o)从集合中删除对象
public boolean removeAll(Collection c)从集合中删除参数指定的所有对象
public void clear()清空集合
public int size()返回包含对象的个数
public boolean isEmpty()判断是否为空
public Object[] toArray()将集合转换为数组
public Iterator iterator()获取当前集合的迭代器

4.2、List

方法声明功能介绍
public void add(int index, E element)向集合中指定位置添加元素
public E get(int index)从集合中获取指定位置元素
public int indexOf(Object o)查找参数指定的对象
public int lastIndexOf(Object o)反向查找参数指定的对象
public E set(int index, E element)修改指定位置的元素
public E remove(int index)删除指定位置的元素
public List subList(int fromIndex, int toIndex)用于获取子List

4.2.1、ArrayList

底层数据结构是数组,查询快,增删慢,线程不安全,效率高,可以存储重复元素

4.2.2、LinkedList

底层数据结构是链表,查询慢,增删快,线程不安全,效率高,可以存储重复元素

特殊方法

方法声明功能介绍
public void addFirst(E e)在该列表开头插入指定的元素
public void addLast(E e)在该列表结尾插入指定的元素
public E getFirst()返回此列表中的第一个元素
public E getLast()返回此列表中的最后一个元素

4.2.3、Vector

底层数据结构是数组,查询快,增删慢,线程安全,效率低,可以存储重复元素

特殊方法

方法声明功能介绍
public void addElement(E obj)将指定的组件添加到此向量的末尾
public E elementAt(int index)返回指定索引处的组件
public Enumeration elements()返回此向量的组件的枚举

4.3、Set

4.3.1、HashSet

采用哈希表实现,元素无序且唯一,线程不安全,效率高,可以存储null元素

4.3.2、LinkedHashSet

采用链表和哈希表共同实现,链表保证了元素的顺序与存储顺序一致,哈希表保证了元素的唯一性。线程不安全,效率高

4.3.3、TreeSet

采用二叉树来实现,元素唯一且已经排好序;唯一性同样需要重写hashCode和equals()方法,二叉树结构保证了元素的有序性

4.4、List和Set总结

  • List特点:元素有放入顺序,元素可重复
  • Set特点:元素无放入顺序,元素不可重复,重复元素会覆盖掉,(注意:元素虽然无放入顺序,但是元素在set中的位置是有该元素的HashCode决定的,其位置其实是固定的,加入Set 的Object必须定义equals()方法)
  • list支持for循环,也就是通过下标来遍历,也可以用迭代器
  • set只能用迭代,因为他无序,无法用下标来取得想要的值
  • Set:检索元素效率低下,删除和插入效率高,插入和删除不会引起元素位置改变
  • List:和数组类似,List可以动态增长,查找元素效率高,插入删除元素效率低,因为会引起其他元素位置改变

5、Map

Map用于保存具有映射关系的数据,Map里保存着两组数据:key和value,它们都可以使任何引用类型的数据,但key不能重复

5.1、方法

方法声明功能介绍
public void clear()删除所有的映射
public boolean containsKey(Object key)判断此映射是否包含指定键的映射
public boolean containsValue(Object value)判断此映射是否包含指定值的映射
public Set<Map.Entry<K,V> entrySet()Map中所包含的键值对所组成的set集合
public V get(Object key)返回指定key所对应的value,如Map中不包含key则返回null
public boolean isEmpty()判断map是否为空
public Set keySet()返回该Map中所有key所组成的set集合
public V put(K key, V value)向Map中添加一个元素
public void putAll(Map<? extends K,? extends V> m)将指定Map的添加到当前Map
public V remove(Object key)从当前Map移除一个key
public int size()Map的键值对的个数
public Collection values()返回该Map里所有value组成的collection

5.2、HashMap

  • 线程不安全
  • HashMap只可以有一个键位null
  • HashMap可以有无数个键值为null
  • 性能很好

5.3、HashTable

  • 线程安全
  • HashTable无论键值都不能为null
  • 性能差

5.4、TreeMap

非线程安全基于红黑树实现

特殊方法

方法声明功能介绍
public Map.Entry<K,V> firstEntry()最小key的键值对
public K firstKey()最小的key
public K lastKey()最大的key
public K higherKey(K key)返回指定key后一位的键
public K lowerKey(K key)返回指定key前一位的键
public K higherEntry(K key)返回指定key后一位的键值对
public K lowerEntry(K key)返回指定key前一位的键值对

5.5、Map的其他类

5.5.1、LinkedHashMap

  • 使用双向链表来维护键值对的次序
  • 迭代顺序与键值对的插入顺序保持一致
  • LinkedHashMap需要维护元素的插入顺序,性能略低于HashMap,但在迭代访问元素时有很好的性能,因为它是以链表来维护内部顺序

5.5.2、IdentityHashMap

使用==判断key是否相等

5.5.3、WeakHashMap

  • WeakHashMap的key所引用的对象没有被其他强引用变量所引用,则这些key所引用的对象可能被回收
  • WeakHashMap中的每个key对象保存了实际对象的弱引用,当回收了该key所对应的实际对象后,WeakHashMap会自动删除该key所对应的键值对

6、Collections

方法声明功能介绍
public static > T max(Collection coll)根据元素的自然顺序返回给定集合的最大元素
public static T max(Collection coll, Comparator comp)根据指定比较器引发的顺序返回给定集合的最大元素
public static > T min(Collection coll)根据元素的自然顺序返回给定集合的最小元素
public static T min(Collection coll, Comparator comp)根据指定比较器引发的顺序返回给定集合的最小元素
public static void copy(List dest, List src)将一个列表中的所有元素复制到 另一个列表中
public static void reverse(List list)反转指定列表中元素的顺序
public static void shuffle(List list)使用默认的随机源随机置换指定的列表
public static > void sort(List list)根据其元素的自然顺序将指定列表按升序排序
public static void sort(List list, Comparator c)根据指定比较器指定的顺序对指定列表进行排序
public static void swap(List list, int i, int j)交换指定列表中指定位置的元素

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/557516.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计划任务文件 linux,Linux之任务计划

一、单次任务计划二、周期性任务计划一、单次任务计划命令&#xff1a;batch&#xff1a;系统空闲时自动执行&#xff0c;不常用at&#xff1a;可以使用相对时间、绝对时间或模糊时间&#xff0c;例如相对时间&#xff1a;at now3min&#xff0c;表示3分钟后执行绝对时间&#…

Java核心类库篇5——异常

Java核心类库篇5——异常 java.lang.Throwable类是Java语言中错误(Error)和异常(Exception)的超类其中Error类主要用于描述Java虚拟机无法解决的严重错误&#xff0c;通常无法编码解决&#xff0c;如&#xff1a;JVM挂掉了 等其中Exception类主要用于描述因编程错误或偶然外在…

linux2019内核版本发布,求问Linux最新内核版本以及发布日期。

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼具有时效性的东西&#xff0c;百度能查处什么鬼来。mainline:4.3-rc32015-09-27[tar.xz][pgp][patch][view diff][browse]stable:4.2.22015-09-29[tar.xz][pgp][patch][inc. patch][view diff][browse][changelog]longterm:4.1.920…

Java核心类库篇6——IO

Java核心类库篇6——IO 1、File 1.1、构造方法 方法声明功能介绍public File(File parent, String child)从父抽象路径名和子路径名字符串创建新的 File实例public File(String pathname)通过将给定的路径名字符串转换为抽象路径名来创建新的 File实例public File(String pa…

linux搭建web服务器原理,【LINUX】linux搭建web服务器

linux httpd假设服务器地址为192.168.80.20/241.将准备安装的httpd软件包共享给everyone&#xff0c;(1)在linux上mount.cifs //真机IP地址/共享文件夹名/media /ls /meidia/查看tar xjvf httpd-2.4.10.tar.bz2 -C /usr/src解压至/usr/src下下面两个插件是httpd2.4以…

Java核心类库篇7——多线程

Java核心类库篇7——多线程 1、程序、进程和线程 程序 - 数据结构 算法&#xff0c;主要指存放在硬盘上的可执行文件进程 - 主要指运行在内存中的可执行文件线程就是进程内部的程序流 操作系统内部支持多 进程的&#xff0c;而每个进程的内部又是支持多线程的 2、线程的创…

Java核心类库篇8——网络编程

Java核心类库篇8——网络编程 1、七层网络模型 OSI&#xff08;Open System Interconnect&#xff09;&#xff0c;即开放式系统互联&#xff0c;是ISO&#xff08;国际标准化组织&#xff09;组织在1985 年研究的网络互连模型。 当发送数据时&#xff0c;需要对发送的内容按…

linux网站如何添加swf支持,linux下安装swftools和openOffice

1.openOffice下载地址&#xff1a;http://download.openoffice.org/all_rc.html#untested-full 下载 Linux 32-bit Intel rpm 包 版本自选 2.安装openOffice 1】 tar -zxvf OOo_3.2.1_Linux_x86_install-rpm-wJRE_zh-CN.tar.gz 2】 cd OOO320_m18_native_packed-1_zh-CN1.openO…

Java番外篇1——正则表达式

Java番外篇1——正则表达式 1、什么是正则表达式 正则表达式定义了字符串的模式正则表达式可以用来搜索、编辑或处理文本正则表达式并不仅限于某一种语言&#xff0c;但是在每种语言中有细微的差别 2、正则表达式规则 2.1、普通字符 普通字符包括没有显式指定为元字符的所…

linux 1号硬盘不能用,linux 挂载硬盘的疑问 : IDE1 上的接口无法使用.

状况说明:我将在linux系统上挂载多块硬盘(目前是redhat9).我通过3块硬盘试验.问题出现:无论如何链接 IDE1 上的硬盘, /dev/hdc 都无法 mount.数据:1. 使用 fdisk -l : 不会显示接到 IDE1 上的硬盘(目前只试验了在 IDE1 上接 1个硬盘,用 master 端口).2. 使用 fdisk /dev/hdc : …

Java番外篇2——jdk8新特性

Java番外篇2——jdk8新特性 1、Lambda 1.1、无参无返回值 public class Test {interface Print{void print();}public static void main(String[] args) { // Print printnew Print() { // Override // public void print() { // …

linux同花顺乱码,打开同花顺软件全是问号

官方答案&#xff1a;字体库字体乱码【原因分析】&#xff1a;系统字体缺失&#xff0c;损坏。【解决方案】方案一&#xff1a;使用360电脑门诊进行修复1.打开【360安全卫士】—【电脑专家】搜索乱码&#xff0c;然后会弹出如下六个解决方案&#xff0c;根据当前计算机的故障现…

Java番外篇3——线程池

Java番外篇3——线程池 1、多线程产生的问题 多次创建并销毁线程。而创建并销毁线程的过程势必会消耗内存 2、线程池 降低系统资源消耗&#xff0c;通过重用已存在的线程&#xff0c;降低线程创建和销毁造成的消耗提高系统响应速度&#xff0c;当有任务到达时&#xff0c;通…

嵌入式linux组件,嵌入式Linux系统的几大组件!

原标题&#xff1a;嵌入式Linux系统的几大组件&#xff01;本文概述了Linux系统的几大组件&#xff0c;描述了这些组件之间的关系。文章解释了术语&#xff0c;并描述看似很基础的细节。每个Linux系统都有许多主要组件。其中一个组件(引导加载程序)从技术上讲是Linux之外的&…

linux iptables找不到,centos /etc/sysconfig/下找不到iptables文件解决方法

本想做些防火墙策略。防火墙策略都是写在/etc/sysconfig/iptables文件里面的。可我发现我也没有这个文件。[rootxiaohuai /]# cd /etc/sysconfig/[rootxiaohuai sysconfig]# lsatd firstboot irqbalance network-scripts rhn sysstatauditd grub kdump ntpd rngd sysstat.iocon…

Java番外篇4——BigInteger与BigDecimal

Java番外篇4——BigInteger与BigDecimal 为了解决大数运算的问题 操作整型&#xff1a;BigInteger操作小数&#xff1a;BigDecimal 1、BigInteger 方法声明功能介绍public BigInteger abs()返回大整数的绝对值public BigInteger add(BigInteger val)返回两个大整数的和publ…

linux cd 命令案例,15个关于Linux的‘cd’命令的练习例子

命令名称&#xff1a;cd代表&#xff1a;切换目录使用平台&#xff1a;所有Linux发行版本执行方式&#xff1a;命令行权限&#xff1a;访问自己的目录或者其余指定目录级别&#xff1a;基础/初学者1.从当前目录切换到/usr/local avitecmint:~$ cd /usr/local avitecmint:/usr/l…

c语言字符串strchr,Strchr()C语言字符串处理功能

strchr()函数不如strcpy()&#xff0c;strcat()&#xff0c;strcmp()&#xff0c;strupr()&#xff0c;strlwr()&#xff0c;strlen()直观c strchr函数&#xff0c;因此需要代码理解:代码来自C语言开发入门和项目实战书:#include#includeint main(){字符字符串[50];char * str&…

Java数据库篇1——数据库配置

Java数据库篇1——数据库配置 1、数据库 数据库(DataBase) 就是存储和管理数据的仓库本质是一个文件系统, 还是以文件的方式,将数据保存在电脑上 2、数据库的优点 存储方式优点缺点内存速度快不能够永久保存,数据是临时状态的文件数据是可以永久保存的使用IO流操作文件, 不…

C语言中输入123求位权,数反转 - it610.com

32位系统c语言中&#xff1a;char取值范围:-128~127unsigned char取值范围:0~255int取值范围:-2147483648~2147483647unsigned int取值范围:0~429496729564位系统下C语言中int还是占4字节&#xff0c;32位&#xff0c;与32位系统中没有区别64位系统下&#xff0c;采用64位编译器…