一、前言
java集合的主要分为三种类型:
1、Set(集) 2、List(列表) 3、Map(映射)
java集合的接口:
1、java集合由两个接口实现,分别为Collection (list、set)和 Map(map),和一个中立的接口 Iterator
2、Collection 与Map接口区别:
a、容器内每个为之所存储的元素个数不同。
b、Collection类型者,每个位置只有一个元素。
c、Map类型者,持有key-value pair,像个小型数据库。
3、各自旗下的子类关系
Collection
--List 将以特定次序存储元素。所以取出来的顺序可能和放入顺序不同。
--ArrayList / LinkedList / Vector
--Set 不能含有重复的元素
--HashSet / TreeSet
Map
--HashMap
--HashTable
--TreeMap
4、中立接口Iterator
a、包含以下方法
hasNext():判断集合中元素是否遍历完毕,如果没有,就返回true
next() :返回下一个元素
remove():从集合中删除上一个有next()方法返回的元素。
b、与Collection、Map的关系
list与set继承至Collection,map集合继承至Map;Collection与Map接口实现了Iterator
换句话说,无论是list,set还是map,都可以通过Iterator 进行遍历。所以我称他是中立的接口;
5、其他特征
a、List,Set,Map将持有对象一律视为Object型别。
b、Collection、List、Set、Map都是接口,不能实例化。继承自它们的 ArrayList, Vector, HashTable, HashMap才能被实例化
c、vector容器确切知道它所持有的对象隶属什么型别。vector不进行边界检查
d、关于Iterator() 和toArray() 方法都用于集合的所有的元素,前者返回一个Iterator对象,后者返回一个包含集合中所有元素的数组。
二、Collection接口
常用方法:
booleanadd(Object o) :向集合中加入一个对象的引用
voidclear():删除集合中所有的对象,即不再持有这些对象的引用
booleanisEmpty() :判断集合是否为空
booleancontains(Object o) : 判断集合中是否持有特定对象的引用
Iterartoriterator() :返回一个Iterator对象,可以用来遍历集合中的元素
booleanremove(Object o) :从集合中删除一个对象的引用
intsize() :返回集合中元素的数目
Object[]toArray() : 返回一个数组,该数组中包括集合中的所有元素
集合详解:
1、list集合
使用方法
package tests;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
public class test {
/**
* 1.list中添加,获取,删除元素;
* 2.遍历取值
* 3.list中是否包含某个元素;
* 4.list中根据索引将元素数值改变(替换);
* 5.list中查看(判断)元素的索引;
* 6.根据元素索引位置进行的判断;
* 7.利用list中索引位置重新生成一个新的list(截取集合);
* 8.对比两个list中的所有元素;
* 9.判断list是否为空;
* 10.去重复;
* 11.返回Iterator集合对象;将集合转换为字符串;将集合转换为数组;
*/
public static void main(String[] args) {
/**
* 1.list中添加,获取,删除元素;
* 添加方法:add(e);获取方法是:get(index);
* 删除方法:remove(index); 按照索引删除;remove(Object o); 按照元素内容删除;
*/
List person=new ArrayList<>();
person.add("jackie"); //索引为0 //.add(e)
person.add("peter"); //索引为1
person.add("annie"); //索引为2
person.add("martin"); //索引为3
person.add("marry"); //索引为4
person.remove(3); //.remove(index)
person.remove("marry"); //.remove(Object o)
String per="";
per=person.get(1);
System.out.println(per); //.get(index) //peter
/**
* 2.list的遍历取值
*/
//第一种 对于ArrayList来说速度比较快, 用for循环, 以size为条件遍历:
for (int i = 0; i < person.size(); i++) {
System.out.println(person.get(i)); //.get(index)
}
//第二种 超级for循环遍历 推荐
for (String p:person) {
System.out.println(p);
}
//第三种 集合类的通用遍历方式, 从很早的版本就有, 用迭代器迭代
Iterator it = person.iterator();
while(it.hasNext()) {
System.out.println(it.next());
}
/**
* 3.list中是否包含某个元素;
* contains(Object o); 返回true或者false
*/
List fruits=new ArrayList<>();
fruits.add("苹果");
fruits.add("香蕉");
fruits.add("桃子");
String appleString="苹果";
//true or false
System.out.println("fruits中是否包含苹果:"+fruits.contains(appleString));
if (fruits.contains(appleString)) { //应用场景
System.out.println("我喜欢吃苹果");
}else {
System.out.println("我不开心");
}
/**
* 4.list中根据索引将元素数值改变(替换);
* 注意 .set(index, element); 和 .add(index, element); 的不同;
*/
String a="白龙马", b="沙和尚", c="八戒", d="唐僧", e="悟空";
List people=new ArrayList<>();
people.add(a);
people.add(b);
people.add(c);
//将d唐僧放到list中索引为0的位置,替换a白龙马
people.set(0, d); //.set(index, element);
//将e悟空放到list中索引为1的位置,原来位置的b沙和尚后移一位
people.add(1, e); //.add(index, element);
System.out.println(people.get(0)); //唐僧
System.out.println(people.get(1)); //悟空
/**
* 5.list中查看(判断)元素的索引;
* 注意:.indexOf(); 和 lastIndexOf()的不同;
*/
List names=new ArrayList<>();
names.add("刘备"); //索引为0
names.add("关羽"); //索引为1
names.add("张飞"); //索引为2
names.add("刘备"); //索引为3
names.add("张飞"); //索引为4
System.out.println(names.indexOf("刘备")); // 0
System.out.println(names.lastIndexOf("刘备")); // 3
System.out.println(names.indexOf("张飞")); //2
System.out.println(names.lastIndexOf("张飞")); //4
/**
* 6.根据元素索引位置进行的判断;
*/
if (names.indexOf("刘备")==0) {
System.out.println("刘备在这里");
}else if (names.lastIndexOf("刘备")==3) {
System.out.println("刘备在那里");
}else {
System.out.println("刘备到底在哪里?");
}
/**
* 7.利用list中索引位置重新生成一个新的list);
* 方法: .subList(fromIndex, toIndex); 截取集合
* 方法: .size() ; 该方法得到list中的元素数的和
*/
List phone=new ArrayList<>();
phone.add("三星"); //索引为0
phone.add("苹果"); //索引为1
phone.add("锤子"); //索引为2
phone.add("华为"); //索引为3
phone.add("小米"); //索引为4
for(String pho:phone){ //原list进行遍历
System.out.println(pho);
}
//生成新list
//利用索引1-4的对象重新生成一个list,但是不包含索引为4的元素,4-1=3
phone=phone.subList(1, 4); //.subList(fromIndex, toIndex)
for (int i = 0; i < phone.size(); i++) {
//新的list包含的元素是苹果 新的list包含的元素是锤子 新的list包含的元素是华为
System.out.println("新的list包含的元素是"+phone.get(i));
}
/**
* 8.对比两个list中的所有元素;
* 两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象
*/
if (person.equals(fruits)) {
System.out.println("两个list中的所有元素相同");
}else {
System.out.println("两个list中的所有元素不一样");
}
if (person.hashCode()==fruits.hashCode()) {
System.out.println("我们相同");
}else {
System.out.println("我们不一样");
}
/**
* 9.判断list是否为空;
* 空则返回true,非空则返回false
*/
if (person.isEmpty()) {
System.out.println("空的");
}else {
System.out.println("不是空的");
}
/**
* 10.去重复
*/
List lst1=new ArrayList<>();
lst1.add("aa");
lst1.add("dd");
lst1.add("ss");
lst1.add("aa");
lst1.add("ss");
//方法 1.
for (int i = 0; i i; j--) {
if (lst1.get(j).equals(lst1.get(i))) {
lst1.remove(j);
}
}
}
System.out.println(lst1);
//方法 2.
List lst2=new ArrayList<>();
for (String s:lst1) {
if (Collections.frequency(lst2, s)<1) {
lst2.add(s);
}
}
System.out.println(lst2);
/**
* 11.其他常用方法
* 返回Iterator集合对象;将集合转换为字符串;将集合转换为数组;
*/
System.out.println("将集合转换为数组:"+person.toArray());
System.out.println("将集合转换为字符串:"+person.toString());
System.out.println("返回Iterator集合对象:"+person.iterator());
}
}
2、set集合
未完待续。。。