目录
java 集合--Set
对于Set下文主要讲HashSet:
1.HashSet的底层其实是HashMap。
插入、用迭代器遍历set
插入重复元素:
因为Set不允许有重复的元素,在插入重复元素时系统不会报错,但系统不会将重复的元素插入到Set集合中。
String是系统类,而自定义的类要重写equals()方法才能实现不允许插入重复数据
打印输出:
插入自定义类对象:
重写:toString、hashCode和equals方法
toString()方法是Object类的方法,我们定义的所有类都是Object类的子类;
如果输出该类的对象,就会自动调用toString()方法,这样会输出该对象的地址;
如果想输出对象的内容,可以在该类中重写toString()方法。
添加:hashCode和equals方法
重写hashCode和equals方法目的时是为了提高查找速度
1、hashCode方法主要用于对数据进行一个预分类
2、后续在进行数据查找时,先按照hashCode判断自己在哪一类
3、然后在相应的类别中用equals方法寻找对应的元素
4、equals方法思路:1)先判断对象是否相等,相等返回true,不用继续比较属性;2)判断obj是否为目标类的对象,若是则通过强制类型转换为目标类对象后继续比较属性值是否相同;3)以上都不满足则返回false
package com.imooc.set;
public class Cat {
private String name; //名字
private int month; //年龄
private String species;//品种
//构造方法
public Cat(String name, int month, String species) {
super();
this.name = name;
this.month = month;
this.species = species;
}
//getter与setter方法
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getMonth() {
return month;
}
public void setMonth(int month) {
this.month = month;
}
public String getSpecies() {
return species;
}
public void setSpecies(String species) {
this.species = species;
}
@Override
public String toString() {
return "[姓名:" + name + ", 年龄:" + month + ", 品种:" + species + "]";
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + month;
result = prime * result + ((name == null) ? 0 : name.hashCode());
result = prime * result + ((species == null) ? 0 : species.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
//判断对象是否相等,相等则返回true,不用继续比较属性了
if(this==obj)
return true;
//判断obj是否是Cat类的对象
if(obj.getClass()==Cat.class){
Cat cat=(Cat)obj;
return cat.getName().equals(name)&&(cat.getMonth()==month)&&(cat.getSpecies().equals(species));
}
return false;
}
}
package com.imooc.set;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
public class CatTest {
public static void main(String[] args) {
// 定义宠物猫对象
Cat huahua = new Cat("花花", 12, "英国短毛猫");
Cat fanfan = new Cat("凡凡", 3, "中华田园猫");
// 将宠物猫对象放入HashSet中
Set<Cat> set = new HashSet<Cat>();
set.add(huahua);
set.add(fanfan);
// 显示宠物猫信息
Iterator<Cat> it = set.iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
// 再添加一个与花花属性一样的猫
Cat huahua01 = new Cat("花花", 12, "英国短毛猫");
set.add(huahua01);
System.out.println("**********************************");
System.out.println("添加重复数据后的宠物猫信息:");
it = set.iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
System.out.println("**********************************");
// 重新插入一个新宠物猫
Cat huahua02 = new Cat("花花二代", 2, "英国短毛猫");
set.add(huahua02);
System.out.println("添加花花二代后的宠物猫信息:");
it = set.iterator();
while (it.hasNext()) {
System.out.println(it.next());
}
System.out.println("**********************************");
// 在集合中查找花花的信息并输出
if (set.contains(huahua)) {
System.out.println("花花找到了!");
System.out.println(huahua);
} else {
System.out.println("花花没找到!");
}
// 在集合中使用名字查找花花的信息
System.out.println("**********************************");
System.out.println("通过名字查找花花信息");
boolean flag = false;
Cat c = null;
it = set.iterator();
while (it.hasNext()) {
c = it.next();
if (c.getName().equals("花花")) {
flag = true;// 找到了
break;
}
}
if (flag) {
System.out.println("花花找到了");
System.out.println(c);
} else {
System.out.println("花花没找到");
}
// 删除花花二代的信息并重新输出
for (Cat cat : set) {
if ("花花二代".equals(cat.getName())) {
set.remove(cat);
break; }
}
System.out.println("**********************************");
System.out.println("删除花花二代后的数据");
for(Cat cat:set){
System.out.println(cat);
}
//删除集合中的所有宠物猫信息
System.out.println("**********************************");
boolean flag1=set.removeAll(set);
if(set.isEmpty()){
System.out.println("猫都不见了。。。");
}else{
System.out.println("猫还在。。。");
}
}
}
查找元素:
查找元素
1、直接通过对象查找,使用contains方法
2、通过属性查找,遍历集合中所有对象,并使用get方法结合equals方法来寻找符合条件的对象
删除元素:
1.删除某个元素:set.remove(obj)
2、清空集合中元素:set.removeAll(set),返回值为true
3、判断集合是否为空:isEmpty()方法,返回true如果集合内没有元素
删除指定一个元素方法:
集合为避免数据不一致性的设计:在读取数据时不允许对数据进行删除,也就是说如果删除这个数据之后还要使用其他数据,就会报错。
最好在删除语句之后跳出循环,break;适合删除符合条件的一个元素。
删除指定多个元素方法:
删除多个元素时:新建一个子集合set1,保存所有符合要求的元素,然后通过set.removeAll(set1)来将这些元素全部删除。