Java类集框架(一)

目录

1.Collection集合接口

2.List 接口 (常用子类 ArrayList ,LinkedList,Vector)

3.Set 集合 接口(常用子类 HashSet  LinkedHashSet,TreeSet)

4.集合输出(iterator , Enumeration)


1.Collection集合接口

Collection是集合中最大父接口,在接口中定义了核心的一些操作。

Collection接口定义的核心方法:

方法名描述方法修饰符参数返回值类型
add(E element)将指定元素添加到集合中publicelement: 要添加的元素boolean
remove(Object o)从集合中移除指定元素publico: 要移除的元素boolean
get(int index)获取集合中指定位置的元素publicindex: 元素的索引E
clear()清空集合中的所有元素public
size()返回集合中的元素数量publicint
toArray()将集合转换为数组publicObject[]
iterator()返回集合的迭代器publicIterator<E>
contains(Object o)检查集合是否包含指定元素publico: 要检查的元素boolean

2.List 接口 (常用子类 ArrayList ,LinkedList,Vector)

List实现了Collection接口,但是自己也扩充了一些方法:

List扩充的方法:

方法名描述
get(int index)获取列表中指定位置的元素
set(int index, E element)用指定元素替换列表中指定位置的元素
ListIterator()返回列表的列表迭代器
foreach(Consumer<? super E> action)对列表中的每个元素执行指定操作

1.ArrayList 线性表

作为一个线性标其存储方式是数组模式,以下是一个ArrayList的案例代码

实现ArrayList存放字符串类型的火车

package Example1801;import java.util.ArrayList;
import java.util.List;public class javaDemo {public static void main(String[] args) {List<String> list = new ArrayList<String>();list.add("火车头");list.add("车厢1");list.add("车厢2");list.add("车厢3");
//        获取基础信息System.out.println("集合是否为空?"+list.isEmpty()+" 集合内容的个数"+list.size());
//        调用方法判断是否存在字符串System.out.println(list.contains("火车头"));
//        获取下标为0的内容System.out.println("下标为0的内容是"+list.get(0));
//        移除数据list.remove("车厢3");
//        非标准输出,了解即可,标准输出接口是Iteratorlist.forEach(str->{System.out.println(str);});
//       清空集合内的数据list.clear();System.out.println(list.isEmpty());}
}

2.LinkedList 链表

作为链表,其实现的方法与火车类似,定义一个空间(车厢)再接在火车最后一列车厢上。

案例代码:

package Example1804;import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;public class javaDemo {public static void main(String[] args) {// 创建链表并插入数据List<String> linkedList = new LinkedList<String>();linkedList.add("火车头");linkedList.add("火车车厢1");linkedList.add("火车车厢2");linkedList.add("火车车厢3");linkedList.add("火车车尾");System.out.println(linkedList);}}

 

数组和链表的最大区别:

1.链表相比于数组不需要频繁的创造新的空间,但是两者的查找效率(get)并不相同,数组的时间复杂度为O(1)而链表的时间复杂度是O(n)

3.Vector

Vector作为原始的程序类由于其应用的广泛性,所以将其保存下来了

案例代码:

package Example1805;import java.util.List;
import java.util.Vector;public class javaDemo {public static void main(String[] args) {
//        泛型<包装类>List<Integer> all = new Vector<Integer>();for (int i = 1;i<=10;i++){all.add(i);}if (!all.isEmpty()){System.out.println(all);}}
}

ArrayList与Vector的区别

ArrayList与Vector首先两者虽然外部调用方法看起来一样,但是二者的源码(内部机制)并不一样,Vector的源码中操作方法中加入了synochronized同步的操作,这就意味着多线程访问二者时候,Vector就会比较安全,但是相应的Vector的效率就会比较低


3.Set 集合 接口(常用子类 HashSet  LinkedHashSet,TreeSet)

 Set与List最大的不同就是,作为一个集合,有互斥性,即不能放同样的数据,或者是同样的数据会被自动覆盖掉,比如做一个统计,统计某个学校学生最喜欢的科目,100个学生但是不可能有100个科目,所以如果有学生是喜欢同样的科目就会自动覆盖。

1.Set的子类HashSet(散列集合)

注意该集合的特点是无序性,以下案例代码就可以看得出其中特性

案例代码:

package Example1806;import java.util.HashSet;
import java.util.Set;public class javaDemo {public static void main(String[] args) {Set<String> all = new HashSet<String>();all.add("火车头");all.add("车厢1");
//        重复数据all.add("车尾");all.add("车尾");System.out.println(all);}
}

 如果想要让HashSet要按照我们顺序输入实现顺序的话就需要用到另一个兄弟类LinkedHashSet以保证其输入的有序性

2.LinkedHashSet

案例代码:

package Example1807;import java.util.LinkedHashMap;
import java.util.LinkedHashSet;
import java.util.Set;public class javaDemo {public static void main(String[] args) {Set<String> all = new LinkedHashSet<String>();all.add("火车头");for (int i =1;i<=10;i++){all.add("火车车厢"+i);}all.add("火车车尾");if (!all.isEmpty()){System.out.println(all);}all.clear();}
}

3.有序集合 TreeSet

有序集合可能会跟刚才的LinkedHashSet联想在一起,实际上并不一样,其中所谓的有序指的是元素的有序性,比如集合中传入一个班级一次考试的成绩,有很大可能并不是按照考试的成绩顺序输入,那么想要实现集合内部自动排好成绩的高低。此时就需要用到TreeSet(有序集合)

案例代码1:

package Example1808;import java.util.Scanner;
import java.util.Set;
import java.util.TreeSet;public class javaDemo {public static void main(String[] args) {System.out.println("欢迎使用成绩等级系统");Set<Integer> all = new TreeSet<Integer>();Scanner scanner = new Scanner(System.in);System.out.println("请输入需要添加的成绩(输入0时候退出系统)");while (true){if (scanner.hasNextInt()){int temp = scanner.nextInt();
//                当输入的成绩位0时候退出系统if (temp == 0){break;}all.add(temp);System.out.println("加入成绩成功");}else {System.out.println("您输入的成绩有问题,请重新输入");}}System.out.println(all);}
}

 

该代码实现了输出一个班同学所有人考试得到的成绩, 然后从低到高输出大家取到过的成绩

4.重复元素消除

问题引出:看如下代码:

package Example1809;import java.util.HashSet;
import java.util.Set;class Member{private String name;private int age;private int id;Member(String name,int age,int id){this.age = age;this.name = name;this.id = id;}@Overridepublic String toString() {return "Member{" +"name='" + name + '\'' +", age=" + age +", id=" + id +'}';}
}
public class javaDemo {public static void main(String[] args) {Set<Member> all = new HashSet<Member>();
//        重复对象all.add(new Member("赵五",20,001));all.add(new Member("赵五",20,001));System.out.println(all);}
}

问:按理来说,add的两个对象其实都是同一个人,如果定义集合Set就应该剔除重复对象,为什么没有剔除呢?

        虽然添加了两个具有相同数据的Member对象,但它们在内存中的地址不同,因此HashSet无法识别它们是相同的对象,也就无法将其视为重复元素进行删除。

        要使HashSet正确识别重复的Member对象,需要在Member类中重写hashCode()和equals()方法,以便根据实际的业务逻辑来判断对象是否重复。例如,可以根据name、age和id属性来判断两个Member对象是否相同。重写这两个方法后,HashSet就能正确地剔除重复对象。

 重复元素消除实现案例代码;

package Example1809;import java.util.HashSet;
import java.util.Objects;
import java.util.Set;class Member{private String name;private int age;private int id;Member(String name,int age,int id){this.age = age;this.name = name;this.id = id;}@Overridepublic boolean equals(Object o) {
//        如果存放的内存地址一样。那么自然就是一样的if (this == o){return true;};
//        检查类型是否相同if (o instanceof Member){Member other = (Member) o;
//            判断所有值是否相同return Objects.equals(this.name,other.name)&&this.age == other.age&&this.id == other.id;}return false;}@Overridepublic int hashCode() {
//        根据name,age,id计算哈希值return Objects.hash(name, age, id);}@Overridepublic String toString() {return "Member{" +"name='" + name + '\'' +", age=" + age +", id=" + id +'}';}
}
public class javaDemo {public static void main(String[] args) {Set<Member> all = new HashSet<Member>();
//        重复对象all.add(new Member("赵五",20,001));all.add(new Member("赵五",20,001));System.out.println(all);}
}

可以看到同样的对象消失了,这样就算实现了重复元素的消除


4.集合输出(迭代器Iterator , Enumeration )

1.迭代器iterator(集合的标准输出)

在前面的Collection中定义的方法

iterator()返回集合的迭代器publicIterator<E>

这一段说明实现集合都可以通过迭代器iterator输出,其创建的实例方法流程是

Iterator iterator = 某个集合.iterator

Iterator接口的常用方法

方法名描述方法修饰符参数返回类型
hasNext()检查迭代器是否还有下一个元素。如果有,则返回true;否则返回false。publicboolean
next()返回迭代器的下一个元素,并将迭代器的位置指向下一个元素。publicE
remove()从迭代器所在的集合中移除迭代器返回的最后一个元素(可选操作)。publicvoid

案例代码;

package Example1803;import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;class Person{private String name;private int age;Person(String name,int age){this.age =age;this.name = name;}public int getAge() {return age;}public String getName() {return name;}
}
public class javaDemo {public static void main(String[] args) {List<Person> personList = new ArrayList<Person>();personList.add(new Person("黄小龙",87));personList.add(new Person("陈非凡",20));personList.add(new Person("陈俊",20));
//        直接输出会输出类的地址System.out.println(personList);
//        通过迭代器遍历输出对象的名称和ageIterator<Person> iterator = personList.iterator();while (iterator.hasNext()){
//            需要有对象接收不能直接输出iterator.next.getName()+iterator.next.getAge
//            这样会出现错误,因为iterator接收数据后立刻就往下走Person person = iterator.next();System.out.println(person.getName()+"的年龄是"+person.getAge());}}
}

 

 熟悉集合类型与Iterator的实现

package Example1810;import java.util.*;public class javaDemo {public static void main(String[] args) {
//        链表List<String> list1 = new LinkedList<String>();list1.add("和平号高铁车头");list1.add("和平号高铁车厢");list1.add("和平号高铁车尾");Iterator<String> iterator1 = list1.iterator();while (iterator1.hasNext()){System.out.println(iterator1.next());}
//        散列集合Set<String> set1 = new HashSet<String>();set1.add("绿皮火车车头");set1.add("绿皮火车车厢");set1.add("绿皮火车车尾");Iterator<String> iterator2 = set1.iterator();while (iterator2.hasNext()){System.out.println(iterator2.next());}
//        有序集合Set<Integer> set2 = new TreeSet<Integer>();set2.add(1);set2.add(2);set2.add(3);Iterator<Integer> iterator3 = set2.iterator();while (iterator3.hasNext()){System.out.println(iterator3.next());}}
}

2.Enumeration

Enumeration该接口与Vector都是原始接口都是在jdk很早前就定义了,该接口主要是用于对Vector的数据输出,在JDK1.5后对其进使用了泛型重新修改

该接口有两个比较常用的方法:

方法名描述
hasMoreElements()检查枚举对象是否有更多的元素可供迭代。如果有,则返回true;否则返回false。
nextElement()返回枚举对象的下一个元素,并将枚举对象的位置指向下一个元素。如果没有更多元素,则会抛出NoSuchElementException异常

案例代码:

package Example1811;import java.util.Enumeration;
import java.util.Vector;public class javaDemo {public static void main(String[] args) {Vector<String> vector = new Vector<>();vector.add("测试1");vector.add("测试2");vector.add("测试3");
//        通过vector的elements实例化Enumeration<String> enumeration = vector.elements();while (enumeration.hasMoreElements()){System.out.println(enumeration.nextElement());}}
}

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

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

相关文章

vue中各种混淆用法汇总

✨在生成、导出、导入、使用 Vue 组件的时候&#xff0c;像我这种新手就会常常被位于不同文件的 new Vue() 、 export default{} 搞得晕头转向。本文对常见用法汇总区分 new Vue() &#x1f4a6;Vue()就是一个构造函数&#xff0c;new Vue()是创建一个 vue 实例。该实例是一个…

Redis - 缓存的双写一致性

概念&#xff1a; 当修改了数据库的数据也要同时更新缓存的数据&#xff0c;缓存和数据库的数据要保持一致 那为什么会有不一致的情况呢&#xff1f; 如果不追求一致性&#xff0c;正常有两种做法 先修改数据库 后删除旧的缓存先删除旧的缓存 再修改数据库 我们以先删除旧的…

html学习9(脚本)

1、<script>标签用于定义客户端脚本&#xff0c;比如JavaScript&#xff0c;既可包含脚本语句&#xff0c;也可通过src属性指向外部文件。 2、JavaScript最常用于图片操作、表单验证及内容动图更新。 3、<noscript>标签用于在浏览器禁用脚本或浏览器不支持脚本&a…

华为数通HCIP-PIM原理与配置

组播网络概念 组播网络由组播源&#xff0c;组播组成员与组播路由器组成。 组播源的主要作用是发送组播数据。 组播组成员的主要作用是接收组播数据&#xff0c;因此需要通过IGMP让组播网络感知组成员位置与加组信息。 组播路由器的主要作用是将数据从组播源发送到组播组成员。…

第七篇:k8s集群使用helm3安装Prometheus Operator

安装Prometheus Operator 目前网上主要有两种安装方式&#xff0c;分别为&#xff1a;1. 使用kubectl基于manifest进行安装 2. 基于helm3进行安装。第一种方式比较繁琐&#xff0c;需要手动配置yaml文件&#xff0c;特别是需要配置pvc相关内容时&#xff0c;涉及到的yaml文件太…

软件测试面试真题 | 什么是PO设计模式?

面试官问&#xff1a;UI自动化测试中有使用过设计模式吗&#xff1f;了解什么是PO设计模式吗&#xff1f; 考察点 《page object 设计模式》&#xff1a;PageObject设计模式的设计思想、设计原则 《web自动化测试实战》&#xff1a;结合PageObject在真实项目中的实践与应用情…

Shell脚本学习-MySQL单实例和多实例启动脚本

已知MySQL多实例启动命令为&#xff1a; mysqld_safe --defaults-file/data/3306/my.cnf & 停止命令为&#xff1a; mysqladmin -uroot -pchang123 -S /data/3306/mysql.sock shutdown 请完成mysql多实例的启动脚本的编写&#xff1a; 问题分析&#xff1a; 要想写出脚…

mybatis-plus 用法

目录 1 快速开始 1.1 依赖准备 1.2 配置准备 1.3 启动服务 2 使用 2.1 实体类注解 2.2 CRUD 2.3 分页 2.4 逻辑删除配置 2.5 通用枚举配置 2.6 自动填充 2.7 多数据源 3 测试 本文主要介绍 mybatis-plus 这款插件&#xff0c;针对 springboot 用户。包括引入&…

Redis 高可用:主从复制、哨兵模式、集群模式

文章目录 一、redis高可用性概述二、主从复制2.1 主从复制2.2 数据同步的方式2.2.1 全量数据同步2.2.2 增量数据同步 2.3 实现原理2.3.1 服务器 RUN ID2.3.2 复制偏移量 offset2.3.3 环形缓冲区 三、哨兵模式3.1 原理3.2 配置3.3 流程3.4 使用3.5 缺点 四、cluster集群4.1 原理…

带头单链表,附带完整测试程序

&#x1f354;链表基础知识 1.概念&#xff1a;链表是由多个节点链接构成的&#xff0c;节点包含数据域和指针域&#xff0c;指针域上存放的指针指向下一个节点 2.链表的种类&#xff1a;按单向或双向、带头或不带头、循环或不循环分为多个种类 3.特点&#xff1a;无法直接找到…

最近写了10篇Java技术博客【SQL和画图组件】

&#xff08;1&#xff09;Java获取SQL语句中的表名 &#xff08;2&#xff09;Java SQL 解析器实践 &#xff08;3&#xff09;Java SQL 格式化实践 &#xff08;4&#xff09;Java 画图 画图组件jgraphx项目整体介绍&#xff08;一&#xff09; 画图组件jgraphx项目导出…

安防视频综合管理合平台EasyCVR可支持的视频播放协议有哪些?

EasyDarwin开源流媒体视频EasyCVR安防监控平台可提供视频监控直播、云端录像、云存储、录像检索与回看、智能告警、平台级联、云台控制、语音对讲、智能分析等能力。 视频监控综合管理平台EasyCVR具备视频融合能力&#xff0c;平台基于云边端一体化架构&#xff0c;具有强大的…

vue卡片轮播图

我的项目是vue3的&#xff0c;用的swiper8 <template><div class"tab-all"><div class"tab-four"><swiper:loop"true":autoplay"{disableOnInteraction:false,delay:3000}":slides-per-view"3":center…

[NLP]LLM高效微调(PEFT)--LoRA

LoRA 背景 神经网络包含很多全连接层&#xff0c;其借助于矩阵乘法得以实现&#xff0c;然而&#xff0c;很多全连接层的权重矩阵都是满秩的。当针对特定任务进行微调后&#xff0c;模型中权重矩阵其实具有很低的本征秩&#xff08;intrinsic rank&#xff09;&#xff0c;因…

c语言实现八大排序详细解析

首先先看排序算法的整体分类 排序&#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作。 稳定性&#xff1a;假定在待排序的记录序列中&#xff0c;存在多个具有相同的关键字的记录&#xff…

为Android构建现代应用——应用导航设计

在前一章节的实现中&#xff0c;Skeleton: Main structure&#xff0c;我们留下了几个 Jetpack 架构组件&#xff0c;这些组件将在本章中使用&#xff0c;例如 Composables、ViewModels、Navigation 和 Hilt。此外&#xff0c;我们还通过 Scaffold 集成了 TopAppBar 和 BottomA…

yolov3-spp 训练结果分析:网络结果可解释性、漏检误检分析

1. valid漏检误检分析 ①为了探查第二层反向找出来的目标特征在最后一层detector上的意义&#xff01;——为什么最后依然可以框出来目标&#xff0c;且mAP还不错的&#xff1f; ②如何进一步提升和改进这个数据的效果&#xff1f;可以有哪些优化数据和改进的地方&#xff1f;让…

《ChatGPT原理最佳解释,从根上理解ChatGPT》

【热点】 2022年11月30日&#xff0c;OpenAI发布ChatGPT&#xff08;全名&#xff1a;Chat Generative Pre-trained Transformer&#xff09;&#xff0c; 即聊天机器人程序 &#xff0c;开启AIGC的研究热潮。 ChatGPT是人工智能技术驱动的自然语言处理工具&#xff0c;它能够…

竞争之王CEO商战课,聚百家企业在京举行

竞争之王CEO商战课&#xff0c;于2023年7月29-31日在北京临空皇冠假日酒店举办&#xff0c;近百家位企业家齐聚一堂&#xff0c;共享饕餮盛宴。 竞争之王CEO商战课是打赢商战的第一课。 竞争环境不是匀速变化&#xff0c;而是加速变化。 在未来的市场环境中&#xff0c;企业间…

Day12-1-Webpack前端工程化开发

Webpack前端工程化 1 案例-webpack打包js文件 1 在index.html中编写代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><me…