一、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集合)的更多相关文章

  1. Java语法基础学习DayTen(集合续)

    一.集合 1.Set:存储的元素是无序的.不可重复的 (1)无序性:无序性不等于随机性,无序指的是元素在底层存储的位置是无序的. (2)不可重复性:当向Set中添加相同的元素时,后添加的元素不能添加进 ...

  2. Java语法基础学习DayTwenty(反射机制续)

    一.Java动态代理 1.代理设计模式的原理 使用一个代理将对象包装起来, 然后用该代理对象取代原始对象. 任何对原始对象的调用都要通过代理. 代理对象决定是否以及何时将方法调用转到原始对象上. 2. ...

  3. Java语法基础学习DayNineteen(反射机制)

    一.Refection定义 1.概述 Reflection(反射)是被视为动态语言的关键,反射机制允许程序在执行期借助于Reflection API取得任何类的内部信息,并能直接操作任意对象的内部属性 ...

  4. Java语法基础学习DayEight

    一.异常处理 1.结构 java.lang.Object |-----java.lang.Throwable |-----java.lang.Error:错误,java程序对此无能为力,不显式处理 | ...

  5. Java语法基础学习DaySeven

    ---恢复内容开始--- 一.包装类——Wrapper 1.定义:针对八种基本数据类型定义相应的引用类型——包装类(封装类) boolean——Boolean          byte——Byte ...

  6. Java语法基础学习DayEighteen(常用类)

    一.String类 1.特点 String代表不可变的字符序列,底层用char[]存放. String是final的. 2.内存解析 3.常用方法 int length() char charAt(i ...

  7. Java语法基础学习DaySix

    一.JavaBean——可重用组件 1.JavaBean是指符合以下标准的Java类: (1)类是公共的 (2)有一个无参的公共的构造器 (3)有属性,且有对应的get.set方法 2.好处 用户可以 ...

  8. Java语法基础学习DayThree

    一.流程控制语句补充 1.switch语句 格式: switch(表达式) { case 值1: 语句体1; break; case 值2: 语句体2; break; ... default: 语句体 ...

  9. Java语法基础学习DayTwentyOne(网络编程)

    一.IP地址和端口号 1.作用 通过IP地址,唯一的定位互联网上一台主机. 端口号标识正在计算机上运行的进程,不同进程有不同的端口号,被规定为一个16位的整数0~65535,其中0~1023被预先定义 ...

随机推荐

  1. LeetCode--405--数字转化为十六进制数

    问题描述: 给定一个整数,编写一个算法将这个数转换为十六进制数.对于负整数,我们通常使用 补码运算 方法. 注意: 十六进制中所有字母(a-f)都必须是小写. 十六进制字符串中不能包含多余的前导零.如 ...

  2. p1530 Fractions to Decimals

    将余数记录下来,如果余数相同,那么商的下一位也相同. #include <iostream> #include <cstdio> #include <cmath> ...

  3. Android Error:Could not find lottie.jar

    Android Error:Could not find lottie.jar 今天遇到了一个及其头疼的问题 同事的工程导到我的电脑里却报错,错误是找不到jcenter仓库里的lottie.jar包 ...

  4. smarty插件

    smarty插件    1.目录:放在Smarty类库下的plugins目录下面(默认存放的都是smarty自带的插件)        smarty3.0提供了自定义插件目录的方式:        $ ...

  5. 378. Kth Smallest Element in a Sorted Matrix(java,优先队列)

    题目: Given a n x n matrix where each of the rows and columns are sorted in ascending order, find the ...

  6. LCS(最长公共子序列)问题

    例题见挑战程序设计竞赛P56 解释:子序列是从原序列中按顺序(可以跳着)抽取出来的,序列是不连续的,这是其和子串最大的区别: 我们可以定义dp数组为dp[i][j],表示的是s1-si和t1-ti对应 ...

  7. 谈一谈HashMap类

    一.Java中的hashCode()和equals() 1. hashCode()的存在主要是用于查找的快捷性,如Hashtable,HashMap等,hashCode()是用来在散列存储结构中确定对 ...

  8. xlrd 安装步骤

    官网 https://pypi.python.org/pypi/xlrd 下载 解压 执行python setup.py install进行安装 --------------------------- ...

  9. Oracle11g温习-第十一章:管理undo

    2013年4月27日 星期六 10:40 1.undo tablespace 功能 undo tablespace 功能:用来存放从datafiles 读出的数据块旧的镜像 [             ...

  10. Alibaba Java Coding Guidelines

    阿里巴巴于10月14日在杭州云栖大会上,正式发布众所期待的<阿里巴巴Java开发规约>扫描插件!该插件由阿里巴巴P3C项目组研发.P3C是世界知名的反潜机,专门对付水下潜水艇,寓意是扫描出 ...