Java语法基础学习DayNine(Java集合)
一、Java集合
1.概述
一方面,面向对象语言对事物的体现都是以对象的形式,为了方便对多个对象的操作,就需要对对象进行存储。另一方面,使用Array存储对象具有一些弊端,而Java集合就像一种容器,可以动态的把多个对象的引用放到容器里。Java集合类可以用于存储数量不等的多个对象,还可以保存具有映射关系的关联数组。
Java集合可分为Collection和Map两种体系:
Collection接口:
|- - - - -Set接口:元素无序、不可重复的集合,类似数学的“集合”
|- - - - -HashSet(主要的实现类)、LinkedHashSet、TreeSet
|- - - - -List接口:元素有序、可重复的集合,“动态“数组
|- - - - -ArrayList(主要的实现类)、LinkedList(链表,有利于频繁的插入删除操作)、Vector(古老的实现类、线程安全的、一般不考虑使用)
Map接口:具有映射关系“key-value对”的集合,类似数学的”函数“ y=f(x)
|- - - - -HashMap、LinkedHashMap、TreeMap、Hashtable(子类:Properties )
2.集合的方法
(1)创建语句
Collection coll = new ArrayList();
(2)size():返回集合中元素的个数
System.out.println(coll.size());//输出0,集合为空
(3)add(Object obj):向集合中添加一个元素
coll.add();
coll.add("AA");
coll.add(new Date());
coll.add(new Person("xiaoming",));
System.out.println(coll.size());//输出4,有四个元素
(4)addAll(Collection coll):将形参coll中包含的所有元素添加到当前集合中
Collection coll2 = Arrays.asList(,,);
coll.addAll(coll2);
System.out.println(coll.size());//输出7,有七个元素
(5)isEmpty():判断集合是否为空
System.out.println(coll.isEmpty());//输出False,不为空
(6)clear():清空集合元素
coll.clear();
System.out.println(coll.isEmpty());//输出True,为空
(7)contains(Object obj):判断集合中是否含指定的对象元素,如果包含则返回True
//判断的依据是根据对象元素所在的类的equals()方法进行判断
//如果存入集合中的元素是自定义的类,需要重写equals()方法!否则将按照Object类中的equals比较对象的内存地址。
boolean b1 = coll.contains(new String("AA"));
System.out.println(b1);//输出true,注意String类重写了equals,比较的是字符串的内容
boolean b2 = coll.contains(new Person("xiaoming",));
System.out.println(b2);//输出false,Person这个自定义类没有重写equals方法,比较的是地址值。
(8)containsAll(Collection coll):判断当前集合中是否包含coll中的所有元素
Collection coll3 = new ArrayList();
coll3.add();
coll3.add("AA");
Boolean b3 = coll.containsAll(coll3);
System.out.println(b3);//输出true
(9)retainAll(Collection coll):求当前集合与coll的共有的元素,返回给当前集合
coll3.add();
coll.retainAll(coll3);
System.out.println(coll);//输出[123,AA]
(10)remove(Object obj):删除集合中的指定元素,删除成功返回true,否则返回false
boolean b4 = coll.remove("BB");
System.out.println(b4);//输出false,没有“BB”这个元素
(11)removeAll(Collection coll):从当前集合中删除包含在coll中的元素
Collection coll = new ArrayList();
coll.add();
coll.add("AA");
coll.add("BB");
coll.add("CC"); Collection coll2 = new ArrayList();
coll2.add();
coll2.add("AA"); coll.removeAll(coll2);
System.out.println(coll);//输出["BB","CC"]
(12)equals(Collection coll):判断集合中所有元素是否完全相同
Collection coll3 = new ArrayList();
coll3.add();
coll3.add(new String("AA"));
System.out.println(coll2.equals(coll3));//输出true
(13)hashCode():暂时跳过
(14)toArray():将集合转化为数组
Object[] obj = coll.toArray();
(15)iterator():返回一个Iterator接口的实现类的对象,进而实现集合的遍历
Iterator iterator = coll.iterator();
while(iterator.hasNext()){//Iterator提供的hasNext()方法返回一个boolean值,用于控制遍历
System.out.println(iterator.next());//next(),返回下一个元素
}
3.集合遍历的方法
(1)使用Iterator实现集合的遍历
Iterator iterator = coll.iterator();
while(iterator.hasNext()){//Iterator提供的hasNext()方法返回一个boolean值,用于控制遍历
System.out.println(iterator.next());//next(),返回下一个元素
}
(2)使用增强for循环实现遍历,也可用于数组的遍历
for(Object obj:coll){
System.out.println(obj);
}
(3)错误的写法
Iterator i = coll.iterator();
while((i.next())!= null){//这里执行了一次next()方法,指针指向下一个元素,导致隔行输出元素
System.out.println(i.next());//,这里又执行了一次next(),可能导致输出空指针,发生Java.util.NoSuchElementException的异常
}
4.ArrayList(List的主要实现类)在List中相对于Collection新增的方法
(1)“增”:void add(int index, Object ele):在指定的索引位置添加元素ele
List list = new ArrayList();
list.add();
list.add();
list.add(new String("AA"));
list.add(,);
System.out.println(list);//输出[555,123,456,AA]
(2)boolean addAll(int index,Collection eles):在指定的索引位置添加eles中的所有元素
(3)”查“:Object get(int index):获取指定索引位置的元素
Object obj = list.get();
System.out.println(obj);//输出555
(4)“删”:Object remove(int index):删除指定索引位置的元素
list.remove();
System.out.println(list.get());//输出123
(5)“改”:Object set(int index, Object ele):设置指定索引位置的元素为ele
list.set(,);
System.out.println(list.get());//输出111
(6)int indexOf(Object obj):返回obj在集合中首次出现的位置,没有的话返回-1
(7)int lastIndexOf(Object obj):返回obj在集合中最后一次出现的位置,没有返回-1
(8)List subList(int fromIndex, int toIndex):返回从fromIndex到toIndex结束的左闭右开的一个子list
List list1 = list.subList(,);
System.out.println(list1);//输出[111,456],不包括AA
Java语法基础学习DayNine(Java集合)的更多相关文章
- Java语法基础学习DayTen(集合续)
一.集合 1.Set:存储的元素是无序的.不可重复的 (1)无序性:无序性不等于随机性,无序指的是元素在底层存储的位置是无序的. (2)不可重复性:当向Set中添加相同的元素时,后添加的元素不能添加进 ...
- Java语法基础学习DayTwenty(反射机制续)
一.Java动态代理 1.代理设计模式的原理 使用一个代理将对象包装起来, 然后用该代理对象取代原始对象. 任何对原始对象的调用都要通过代理. 代理对象决定是否以及何时将方法调用转到原始对象上. 2. ...
- Java语法基础学习DayNineteen(反射机制)
一.Refection定义 1.概述 Reflection(反射)是被视为动态语言的关键,反射机制允许程序在执行期借助于Reflection API取得任何类的内部信息,并能直接操作任意对象的内部属性 ...
- Java语法基础学习DayEight
一.异常处理 1.结构 java.lang.Object |-----java.lang.Throwable |-----java.lang.Error:错误,java程序对此无能为力,不显式处理 | ...
- Java语法基础学习DaySeven
---恢复内容开始--- 一.包装类——Wrapper 1.定义:针对八种基本数据类型定义相应的引用类型——包装类(封装类) boolean——Boolean byte——Byte ...
- Java语法基础学习DayEighteen(常用类)
一.String类 1.特点 String代表不可变的字符序列,底层用char[]存放. String是final的. 2.内存解析 3.常用方法 int length() char charAt(i ...
- Java语法基础学习DaySix
一.JavaBean——可重用组件 1.JavaBean是指符合以下标准的Java类: (1)类是公共的 (2)有一个无参的公共的构造器 (3)有属性,且有对应的get.set方法 2.好处 用户可以 ...
- Java语法基础学习DayThree
一.流程控制语句补充 1.switch语句 格式: switch(表达式) { case 值1: 语句体1; break; case 值2: 语句体2; break; ... default: 语句体 ...
- Java语法基础学习DayTwentyOne(网络编程)
一.IP地址和端口号 1.作用 通过IP地址,唯一的定位互联网上一台主机. 端口号标识正在计算机上运行的进程,不同进程有不同的端口号,被规定为一个16位的整数0~65535,其中0~1023被预先定义 ...
随机推荐
- a gcc 4.2.4 bug(被stos指令累加后%edi作为参数的)
a gcc 4.2.4 bug(被stos指令累加后%edi作为参数的) * * Ok, now we can initialize the rest of the tty devices and c ...
- fdisk分区和挂载
查看硬盘情况 fdisk -l 修改分区类型为LVM sudo fdisk /dev/sda (/dev/sda为对应的设备名,也可能是其它名字) 按n新建分区 按p选择主分区 按t改变分区的syst ...
- python 日期操作【转】
SQLite中的时间日期函数这是我学习SQLite时做的笔记,参考并翻译了Chris Newman写的<SQLite>中的<Working with Dates and Times& ...
- 创建xml树
XMLElement 节点XMLDocument 节点的CUID操作 XMLNode 抽象类 操作节点 (XMLElement XMLDocument ) XElement xElement = ne ...
- MongoDB\BSON\UTCDateTime::toDateTime
示例# 1 MongoDB \ BSON \ UTCDatetime:toDateTime()例子 <?php $utcdatetime = new MongoDB\BSON\UTCDateTi ...
- Spring注解之@Transactional对于事务异常的处理
spring对于事务异常的处理 unchecked 运行期Exception spring默认会进行事务回滚 比如:RuntimeException checked 用 ...
- MySql(九)索引
一.索引的介绍 数据库中专门用于帮助用户快速查找数据的一种数据结构.类似于字典中的目录,查找字典内容时可以根据目录查找到数据的存放位置吗,然后直接获取. 二 .索引的作用 约束和加速查找 三.常见的几 ...
- 《高性能SQL调优精要与案例解析》一书谈主流关系库SQL调优(SQL TUNING或SQL优化)核心机制之——索引(index)
继<高性能SQL调优精要与案例解析>一书谈SQL调优(SQL TUNING或SQL优化),我们今天就谈谈各主流关系库中,占据SQL调优技术和工作半壁江山的.最重要的核心机制之一——索引(i ...
- nmon+nmon analyser安装使用教程
nmon一般是两种用法,一是交互式用法查看实时的内存/cpu/网络/磁盘等情况,二是抓取一段时间内的实时的内存/cpu/网络/磁盘记到csv格式的.nmon文件中然后用nmon analyse做可视化 ...
- AIX安装JDK1.7教程
1.下载 下载链接(下载需要登录IBM账号):https://www.ibm.com/developerworks/java/jdk/aix/service.html#i1 由于jdk版本AIX操作系 ...