hashSet笔记

package com.jenthor;

import java.util.*;

/*
 * |---Set: 元素是无序的(存入和取出的顺序不一定一致),元素不可以重复
 * 		|---HashSet:底层数 据结构是哈希表
 * 		|---TreeSet
 * Set集合的功能和Collection的功能是一致的。
 * 
 * 
 * 
 * 往HashSet集合中存入自定对象
 * 姓名和年龄相同为同一个人,(重复元素)
 */
public class HashSetDemo {
	public static void main(String[] args) {
		/*
		 * Demo d1 = new Demo(); Demo d2 = new Demo();
		 * 
		 * System.out.println(d1); System.out.println(d2);
		 */
		/*
		 * HashSet hs=new HashSet(); hs.add("java01"); hs.add("java02");
		 * hs.add("java03"); hs.add("java04"); hs.add("java03");
		 * //System.out.println(hs.add("java04")); add方法的放回是boolean型
		 * 
		 * Iterator in=hs.iterator(); while(in.hasNext()){
		 * System.out.println(in.next());
		 */

		HashSet hs = new HashSet();
		hs.add(new Person("a1", 9));
		hs.add(new Person("a1", 10));
		hs.add(new Person("a3", 13));
		hs.add(new Person("a4", 14));
		hs.add(new Person("a3", 13));

		Iterator it = hs.iterator();
		while (it.hasNext()) {
			Person p = (Person) it.next();
			System.out.println(p.getName() + ".." + p.getAge());
		}

	}
}

class Person {
	private String name;
	private int age;

	Person(String name, int age) {
		this.name = name;
		this.age = age;
	}

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

	public String getName() {
		return name;
	}

	public int getAge() {
		return age;
	}

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

	public int hashCode() {
		return name.hashCode()+age*23;
	}

	public boolean equals(Object obj) {
		if (!(obj instanceof Person))
			return false;
		Person p = (Person) obj;
		System.out.println(this.name+"....."+p.name);
		return (this.name.equals(p.name) && this.age == p.age);
	}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值