java中Set用法

set 与list相比,是无顺序的,去除重复项(重写Hashset和equals方法后)。

package my.lists;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Scanner;
import java.util.Set;
import java.util.List;
public class Student{
	private String name;
	private int age;
	public Student(String name,int age) {
		this.name=name;
		this.age=age;
	}
	
	
	public String getName() {
		return name;
	}


	public void setName(String name) {
		this.name = name;
	}


	public int getAge() {
		return age;
	}


	public void setAge(int age) {
		this.age = age;
	}


	@Override
	public String toString() {
		return "Student [name=" + name + ", age=" + age + "]";
	}


	public static void main(String[] args) {
		Set<Student> stuL=new HashSet<Student>();
		Student stu1=new Student("a橘子",1);
		Student stu2=new Student("b香蕉",2);
		Student stu3=new Student("c苹果",3);
		Student stu4=new Student("d草莓",4);
		Student stu5=new Student("e橙子",5);
		Student stu6=new Student("f柚子",6);
		Student stu7=new Student("g梨",7);
		Student stu8=new Student("h葡萄",8);
		stuL.add(stu1);
		stuL.add(stu2);
		stuL.add(stu3);
		stuL.add(stu4);
		stuL.add(stu5);
		stuL.add(stu6);
		stuL.add(stu7);
		stuL.add(stu8);
		Iterator<Student> iter=stuL.iterator();
		while(iter.hasNext()) {
			System.out.println(iter.next());
		}
		
	}
}

 

hashSet去除重复是调用对象的HashCode 和equals方法。

package my.lists;

import java.util.ArrayList;
import java.util.Collections;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Scanner;
import java.util.Set;
import java.util.List;
public class Student{
	private String name;
	private int age;
	public Student(String name,int age) {
		this.name=name;
		this.age=age;
	}
	
	
	public String getName() {
		return name;
	}


	public void setName(String name) {
		this.name = name;
	}


	public int getAge() {
		return age;
	}


	public void setAge(int age) {
		this.age = age;
	}


	@Override
	public int hashCode() {
		final int prime = 31;
		int result = 1;
		result = prime * result + age;
		result = prime * result + ((name == null) ? 0 : name.hashCode());
		return result;
	}


	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		Student other = (Student) obj;
		if (age != other.age)
			return false;
		if (name == null) {
			if (other.name != null)
				return false;
		} else if (!name.equals(other.name))
			return false;
		return true;
	}


	@Override
	public String toString() {
		return "Student [name=" + name + ", age=" + age + "]";
	}
	
	public static void main(String[] args) {
		Set<Student> stuL=new HashSet<Student>();
		Student stu1=new Student("a橘子",1);
		Student stu2=new Student("b香蕉",2);
		Student stu3=new Student("c苹果",3);
		Student stu9=new Student("c苹果",3);
		Student stu4=new Student("d草莓",4);
		Student stu5=new Student("e橙子",5);
		Student stu6=new Student("f柚子",6);
		Student stu7=new Student("g梨",7);
		Student stu8=new Student("h葡萄",8);
		stuL.add(stu1);
		stuL.add(stu2);
		stuL.add(stu3);
		stuL.add(stu4);
		stuL.add(stu5);
		stuL.add(stu6);
		stuL.add(stu7);
		stuL.add(stu8);
		stuL.add(stu9);
		Iterator<Student> iter=stuL.iterator();
		while(iter.hasNext()) {
			System.out.println(iter.next());
		}
		
	}



}

运行的结果是:

 如果不重写equals方法,hashCode方法,则可以存在相同的对象。

 

Java中,Set是一种集合类型,它不允许重复元素,并且没有固定的顺序。常见的Set实现类有HashSet、LinkedHashSet和TreeSet。下面是Set用法示例: 1. 创建Set对象 可以使用以下语法创建Set对象: ```java Set<T> set = new HashSet<>(); // 创建HashSet对象 Set<T> set = new LinkedHashSet<>(); // 创建LinkedHashSet对象 Set<T> set = new TreeSet<>(); // 创建TreeSet对象 ``` 其中,T表示元素的类型。 2. 添加元素 可以使用add()方法向Set中添加元素: ```java set.add(element); // 将元素添加到Set中,如果Set中已经存在该元素,add()方法不会执行任何操作 ``` 3. 删除元素 可以使用remove()方法从Set中删除元素: ```java set.remove(element); // 从Set中删除指定元素,如果Set中不存在该元素,remove()方法不会执行任何操作 ``` 4. 判断元素是否存在 可以使用contains()方法判断Set中是否存在指定元素: ```java set.contains(element); // 如果Set中存在该元素,返回true;否则返回false ``` 5. 遍历元素 可以使用foreach循环或者迭代器遍历Set中的元素: ```java for (T element : set) { // 对元素进行操作 } Iterator<T> iterator = set.iterator(); while (iterator.hasNext()) { T element = iterator.next(); // 对元素进行操作 } ``` 6. 获取元素个数 可以使用size()方法获取Set中元素的个数: ```java set.size(); // 返回Set中元素的个数 ``` 7. 清空Set 可以使用clear()方法清空Set中的所有元素: ```java set.clear(); // 清空Set中的所有元素 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值