HashSet集合

HashSet集合


1、Collection集合

         |--List:有序(存储顺序和取出顺序一致),集合中的元素可以重复。                    

         |--Set:无序(存储顺序和取出顺序不一致),集合中的元素不可以重复。


2、HashSet集合

(1)HashSet概述

            HashSet:它不保证 set 的迭代顺序;特别是它不保证该顺序恒久不变。

            注意:虽然Set集合的元素无序,但是,作为集合来说,它肯定有它自己的存储顺序,而你存放元素的顺序恰好和它的存储顺序一致,这代表不了Set集合是有序的,你可以多存储一些数据,就能看到效果。

(2)HashSet中存储字符串的代码演示:

package cn.itcast_01;

import java.util.HashSet;
import java.util.Set;
public class SetDemo {
	public static void main(String[] args) {
		// 创建集合对象
		Set<String> set = new HashSet<String>();

		// 创建并添加元素
		set.add("hello");
		set.add("java");
		set.add("world");
		//set.add("java");
		//set.add("world");

		// 增强for
		for (String s : set) {
			System.out.println(s);
		}
	}
}


(3)HashSet中存储自定义对象的代码演示:

        A:Dog类
package cn.itcast_01;

public class Dog {
	private String name;
	private int age;
	private String color;
	private char sex;

	public Dog() {
		super();
	}

	public Dog(String name, int age, String color, char sex) {
		super();
		this.name = name;
		this.age = age;
		this.color = color;
		this.sex = sex;
	}

	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;
	}

	public String getColor() {
		return color;
	}

	public void setColor(String color) {
		this.color = color;
	}

	public char getSex() {
		return sex;
	}

	public void setSex(char sex) {
		this.sex = sex;
	}

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

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

	

}
        B:测试类
package cn.itcast_01;

import java.util.HashSet;

/*
 * HashSet集合存储自定义对象并遍历。如果对象的成员变量值相同即为同一个对象
 * 
 * 注意了:
 * 		你使用的是HashSet集合,这个集合的底层是哈希表结构。
 * 		而哈希表结构底层依赖:hashCode()和equals()方法。
 * 		如果你认为对象的成员变量值相同即为同一个对象的话,你就应该重写这两个方法。
 * 		如何重写呢?不同担心,自动生成即可。
 */

public class HashSetDemo {
	public static void main(String[] args) {
		// 创建集合对象
		HashSet<Dog> hs = new HashSet<Dog>();

		// 创建狗对象
		Dog d1 = new Dog("亲", 25, "红色", '男');
		Dog d2 = new Dog("高", 22, "黑色", '女');
		Dog d3 = new Dog("亲", 25, "红色", '男');
		Dog d4 = new Dog("亲", 20, "红色", '女');
		Dog d5 = new Dog("嘿", 28, "白色", '男');
		Dog d6 = new Dog("哇", 23, "黄色", '女');
		Dog d7 = new Dog("哇", 23, "黄色", '女');
		Dog d8 = new Dog("哇", 23, "黄色", '男');

		// 添加元素
		hs.add(d1);
		hs.add(d2);
		hs.add(d3);
		hs.add(d4);
		hs.add(d5);
		hs.add(d6);
		hs.add(d7);
		hs.add(d8);

		// 遍历
		for (Dog d : hs) {
			System.out.println(d.getName() + "---" + d.getAge() + "---" + d.getColor() + "---" + d.getSex());
		}
	}
}





ArrayList和HashSet都是Java中常用的集合类。ArrayList是一个动态数组,可以根据需要自动扩展容量,而HashSet是一个基于哈希表的集合,它不允许重复元素,可以用于去重。下面是它们的一些特点和常用方法: ArrayList: - 可以存储重复元素,可以根据下标访问元素。 - 添加元素使用add()方法,删除元素使用remove()方法,获取元素使用get()方法。 - 可以使用for循环或者迭代器遍历元素。 - 底层实现是一个数组,当数组容量不足时会自动扩容。 HashSet: - 不允许存储重复元素,可以用于去重。 - 添加元素使用add()方法,删除元素使用remove()方法,查询元素使用contains()方法。 - 可以使用for循环或者迭代器遍历元素。 - 底层实现是一个哈希表,当元素数量过多时会自动扩容。 下面是一个示例代码,演示了如何使用ArrayList和HashSet: ```java import java.util.ArrayList; import java.util.HashSet; public class Main { public static void main(String[] args) { // 创建一个ArrayList ArrayList<String> arrayList = new ArrayList<>(); // 添加元素 arrayList.add("apple"); arrayList.add("banana"); arrayList.add("orange"); // 遍历元素 for (String fruit : arrayList) { System.out.println(fruit); } // 创建一个HashSet HashSet<String> hashSet = new HashSet<>(); // 添加元素 hashSet.add("apple"); hashSet.add("banana"); hashSet.add("orange"); hashSet.add("apple"); // 添加重复元素 // 遍历元素 for (String fruit : hashSet) { System.out.println(fruit); } } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值