HashMap集合存储自定义对象

//HashMap<Student,String>
//键:学生类型(自定义类型)
//值:字符串类型

//键是自定义类型:要保证键不重复的对象,对于该自定义类必须重写
//Object类中的equals()和hashCode()方法

//HashSet<Student>add方法依赖于HashMap实例里面的put()方法

import java.util.HashMap;
import java.util.Set;
public class HashMapDemo3 {
	public static void main(String[] args) {
		//创建HashMap集合对象
		HashMap<Student,String>hm=new HashMap<Student,String>();
		//添加元素
		Student s1=new Student("张三",22);
		Student s2=new Student("赵三",26);
		Student s3=new Student("赵三",26);
		Student s4=new Student("刘三",27);
		Student s5=new Student("张三",22);
		Student s6=new Student("赵三",26);
		//添加元素
		hm.put(s1, "001");
		hm.put(s2, "001");
		hm.put(s3, "001");
		hm.put(s4, "001");
		hm.put(s5, "001");
		hm.put(s6, "001");
		//获取所有的键
		Set<Student>set=hm.keySet();
		for(Student s:set) {
			String v=hm.get(s);
			System.out.println(s.getName()+"--"+s.getAge()+"--"+v);
		}
	}
}

 

 

import java.util.Objects;

public class Student {
	private String name;
	private int age;
	public Student() {
		super();
		// TODO Auto-generated constructor stub
	}

	public Student(String name, int age) {
		super();
		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 + "]";
	}

	@Override
	public int hashCode() {
		return Objects.hash(age, name);
	}

	@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;
		return age == other.age && Objects.equals(name, other.name);
	}

	
	
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
掌握集合的概念、体系结构、分类及使用场景 2)了解Set接口及主要实现类(HashSet、TreeSet) 3)了解List接口及主要实现类(ArrayList、LinkedList、Vector) 4)了解Map接口及主要实现类(HashMap、TreeMap、HashTable) 二、实验内容及步骤 1、编写程序练习将以下5个Person类的对象放在一个HashSet。 姓名:张三 身份证号:178880001 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880003 姓名:王五 身份证号:178880002 姓名:李四 身份证号:178880004 注意:因为Person类是自定义类,需要重写hashCode()方法和equals()方法,并规定只有姓名和身份证号都相等,则对象相等。 其计算哈希码的算法:(31 + ((name == null) ? 0 : name.hashCode()))*31 + id (注:name:Person对象的姓名,id:Person对象的身份证号) 主方法作如下测试: 1)创建一个可放置Person类对象的HashSet; 2)依次添加上述5个对象到HashSet; 3)把集合的元素打印出来(使用迭代器Iterator) 2、编写程序练习List集合的基本使用: 1) 创建一个只能容纳String对象名为names的ArrayList集合; 2)按顺序往集合添加5个字符串对象:"张三"、"李四"、"王五"、"马六"、"赵七"; 3)对集合进行遍历,分别打印集合的每个元素的位置与内容; 4)打印集合的大小,然后删除集合的第3个元素,并显示删除元素的内容,然后再打印目前集合第3个元素的内容,并再次打印集合的大小。 3、编写程序练习Map集合的基本使用: 1)创建一个只能容纳String对象的person的HashMap集合; 2)往集合添加5个"键-值"对象: "id"-"1"; "name"-"张三"; "sex"-"男"; "age"-"25"; "hobby"-"爱学Java" 3)对集合进行遍历,分别打印集合的每个元素的键与值; 4)打印集合的大小,然后删除集合的键为age的元素,并显示删除元素的内容,并再次打印集合的大小。 四、思考题 1、集合的List、Set、Map有哪些不同? 2、为什么使用集合框架,而尽可能少用数组作为存储结构? 3、如何使用TreeSet实现第一题?
HashMap可以存放自定义对象。在给HashMap添加元素时,键值对的键可以是自定义对象,值可以是任何类型的对象。但是,在使用自定义对象作为键时,需要确保自定义对象正确地实现了hashCode()和equals()方法。这是因为HashMap在判断键是否相同时会依赖于hashCode()和equals()方法的实现。 在给HashMap添加自定义对象时,可以复写自定义类的hashCode()和equals()方法来确保键的唯一性。在上面的示例,Student类重写了hashCode()和equals()方法,以确保当name和age相同时,对象被视为相同的键。这样,即使添加了多个相同属性的Student对象,它们仍然被视为相同的键。 通过复写hashCode()和equals()方法,HashMap可以正确地将自定义对象作为键进行存储和查找。这样,可以方便地通过自定义对象来获取相应的值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [HashMap集合存储自定义对象](https://blog.csdn.net/weixin_57219176/article/details/124340641)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [HashMap存储自定义对象](https://blog.csdn.net/houguofei123/article/details/81712692)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值