Java中Map的用法整理

一、HashMap

常用函数:
添加功能
V put(K key,V value):添加元素。这个其实还有另一个功能
如果键是第一次存储,就直接存储元素,返回null
如果键不是第一次存在,就用值把以前的值替换掉,返回以前的值

删除功能
void clear():移除所有的键值对元素
V remove(Object key):根据键删除键值对元素,并把值返回

判断功能
boolean containsKey(Object key):判断集合是否包含指定的键
boolean containsValue(Object value):判断集合是否包含指定的值
boolean isEmpty():判断集合是否为空

获取功能
Set<Map.Entry<K,V>> entrySet(): 返回一个键值对的Set集合
V get(Object key):根据键获取值
Set keySet():获取集合中所有键的集合
Collection values():获取集合中所有值的集合

长度功能
int size():返回集合中的键值对的对数

Map的初始化:

HashMap<K,V> mp=new HashMap<>();//hashmap(底层由hash表实现)
TreeMap<K,V> mp=new TreeMap<>();//treemap(底层由红黑树实现,键有序)

Map的遍历(利用keyset遍历):

import java.util.HashMap;
import java.util.Iterator;
import java.util.Set;

class stu1{	
	int age;
	String name;
	
	public stu1(int ii,String na){
		this.age=ii;
		this.name=na;
	}

	public int getAge() {
		return age;
	}

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

	public String getName() {
		return name;
	}

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

public class Main {	
	public static void main(String[] args) {
		HashMap<Integer, stu1> mp=new HashMap<>();
		mp.put(1, new stu1(12, "张三"));
		mp.put(2, new stu1(14, "李四"));
		mp.put(3, new stu1(15, "王五"));
		
		Set<Integer> set=mp.keySet();
		Iterator<Integer> iterator=set.iterator();
		while(iterator.hasNext()) {
			int idd=iterator.next();
			stu1 ss=mp.get(idd);
			System.out.println(idd+" "+ss.getAge()+" "+ss.getName());
		}
	}
}

Map的遍历(entrySet遍历):

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;

class stu1{
	int age;
	String name;
	
	public stu1(int ii,String na){
		this.age=ii;
		this.name=na;
	}

	public int getAge() {
		return age;
	}

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

	public String getName() {
		return name;
	}

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

public class Main {	
	public static void main(String[] args) {
		HashMap<Integer, stu1> mp=new HashMap<>();
		mp.put(1, new stu1(12, "张三"));
		mp.put(2, new stu1(14, "李四"));
		mp.put(3, new stu1(15, "王五"));
		
		Set<Map.Entry<Integer, stu1> > entries=mp.entrySet();
		for(Map.Entry<Integer, stu1> ent : entries) {
			System.out.println(ent.getKey()+" "+ent.getValue().getAge()+" "+ent.getValue().getName());
		}		
	}
}

二、TreeMap

根据Key由小到大排序;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

class stu1{
	int age;
	String name;
	
	public stu1(int ii,String na){
		this.age=ii;
		this.name=na;
	}

	public int getAge() {
		return age;
	}

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

	public String getName() {
		return name;
	}

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

public class Main {	
	public static void main(String[] args) {
		TreeMap<Integer, stu1> mp=new TreeMap<>();
		mp.put(1, new stu1(12, "张三"));
		mp.put(4, new stu1(10, "李四"));
		mp.put(3, new stu1(15, "王五"));
		Set<Map.Entry<Integer, stu1> > entries=mp.entrySet();
		for(Map.Entry<Integer, stu1> ent : entries) {
			System.out.println(ent.getKey()+" "+ent.getValue().getAge()+" "+ent.getValue().getName());
		}		
	}
}

如果自定义类为Key,自定义类需要实现Comparable接口(其中的compareTo方法):

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;

class stu1 implements Comparable<stu1>{
	int age;
	String name;
	
	public stu1(int ii,String na){
		this.age=ii;
		this.name=na;
	}

	public int getAge() {
		return age;
	}

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

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
	
	public int compareTo(stu1 s) {//根据年龄降序排序
		return s.age-this.age;
	}
}

public class Main {	
	public static void main(String[] args) {
		TreeMap<stu1, Integer> mp=new TreeMap<>();
		mp.put( new stu1(12, "张三"),1);
		mp.put (new stu1(1, "李四"),2);
		mp.put( new stu1(15, "王五"),3);
		
		Set<Map.Entry< stu1,Integer> > entries=mp.entrySet();
		for(Map.Entry<stu1, Integer> ent : entries) {
			System.out.println("age: "+ent.getKey().age+" name: "+ent.getKey().name+" id: "+ent.getValue());
		}		
	}
}

注意:
如果根据年龄降序,this.age在后面;
public int compareTo(stu1 s) {
return s.age-this.age;
}
如果根据年龄升序,this.age在前面;
public int compareTo(stu1 s) {//根据年龄降序排序
return this.age-s.age;
}

  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
很抱歉,我没有找到关于unordered_mapJava用法的引用内容。然而,Java提供了类似的数据结构HashMap,它可以用来实现unordered_map的功能。在Java,可以使用HashMap来存储键值对,并且可以通过键来快速访问值。以下是unordered_map的一些常见用法Java等价代码: 1. 创建HashMap对象: ```java HashMap<KeyType, ValueType> map = new HashMap<>(); ``` 2. 添加键值对: ```java map.put(key, value); ``` 3. 获取值: ```java ValueType value = map.get(key); ``` 4. 检查键是否存在: ```java boolean containsKey = map.containsKey(key); ``` 5. 删除键值对: ```java map.remove(key); ``` 6. 遍历键值对: ```java for (Map.Entry<KeyType, ValueType> entry : map.entrySet()) { KeyType key = entry.getKey(); ValueType value = entry.getValue(); // 进行相应的操作 } ``` 请记住,Java的HashMap在内部使用哈希表实现,因此其元素的顺序可能是无序的。如果需要有序的键值对集合,可以考虑使用有序的数据结构,如TreeMap。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [12 STL【unordered_map介绍】【unordered_map获取/添加/删除元素 成员函数】【unordered_multimap】...](https://blog.csdn.net/weixin_44484715/article/details/116083724)[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* [map/unordered_map原理和使用整理](https://blog.csdn.net/Blues1021/article/details/45054159)[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、付费专栏及课程。

余额充值