集合框架Map

集合框架Map介绍

map集合中存放的都是一组组映射关系,一个键对应一个值,并且键不能重复。
它有三个子类:Hashtable,HashMap,TreeMap。我们常用的也就是HashMap和TreeMap。
几个主要的方法就是put,entrySet,keySet.

1.put:添加集合元素的同时,他可以编辑原有的元素.如果说集合中没有key对应的value,那么就往集合中添加元素.如果说集合中对应的key有value值,则代表替换原有的值。返回值为替换前key对应的value值。
在这里插入图片描述
2.entrySet:map集合没有自己的迭代器,于是我们就得用到entrySet方法进行集合的遍历,
可以把map集合里的键和值一起取出来
在这里插入图片描述
3.keySet:可以把map集合里的键取出来,也是可以用来遍历map集合的。
在这里插入图片描述
还有一些方法请点击链接查看在线文档

Map集合的一些应用

  1. 将学生作为键,地址作为值进行存储,名字年龄相同则被认定为一个人,最后输出。

    这里我们就要用到HashMap,建立一个student类,实例化作为key添加到map集合,然后对学生进行判重
    在这里插入图片描述
    判重的方法和HashSet的判重方法一样。

  2. 然后按年龄进行排序

    这里因为要进行排序,所以就要用到TreeMap。方法也和TreeSet的方法一样。
    先要让对象具有比较方式,实现Comparable接口,重写compare方法。

class Student implements Comparable<Student>{}
@Override
	public int compareTo(Student o) {
		// TODO Auto-generated method stub
		System.out.println(1);
		int num=this.getAge()-o.getAge();
		if(num==0) {
			return this.getName().compareTo(o.getName());
		}
		return num;
	}

3.需求改变、按姓名进行排序

这里我们要自己定义一个比较器,定义一个类,实现comparator接口,实现compare方法

class StuComp implements Comparator<Student>{

	@Override
	public int compare(Student o1, Student o2) {
		// TODO Auto-generated method stub
		int num=o1.getName().compareTo(o2.getName());
		if(num==0) {
			return o1.getAge()-o2.getAge();
		}
		return num;
	}
	
}

让集合自身具备比较在集合初始化时,就有了比较方式。

Map<Student, String> map=new TreeMap<>(new StuComp());

4.统计一个字符串中字符出现次数
将字符串转为字符串数组,将这个字符串中的字符仿作map集合里的key,将出现的次数作为value值。当字符第一次出现的时候,用它在集合中进行寻找,返回值必然为null,之后将该字符对应的值改为1。如果该字符不是第一次出现,该字符对应的值加一。

public class HashMapDemo {
	public static void main(String[] args) {
		String str="sfgsregsrrfgsreggergsegdssshtjd";
		str=cishu(str);
		System.out.println(str);
	}
	/**
	 * 字符出现次数统计功能
	 * @param str
	 * @return
	 */
	public static String cishu(String str) {
		char[] charArray = str.toCharArray();
		//map集合中的泛型要使用包装类,或者是引用数据类型
		Map<Character, Integer> map=new TreeMap<>();
		for (char c : charArray) {
			Integer value=map.get(c);
			if(value==null) {
				map.put(c, 1);
			}
			else {
				map.put(c, ++value);
			}
		}

		StringBuffer sb=new StringBuffer();
		Set<Entry<Character, Integer>> entrySet = map.entrySet();
		for (Entry<Character, Integer> entry : entrySet) {
			sb.append(entry.getKey()+"("+entry.getValue()+")");
		}
		return sb.toString();
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: Java集合框架中的Map是一种键值对的数据结构,可以存储一组具有唯一键和对应值的元素。使用泛型可以在编译时进行类型检查,确保集合中只能存储指定类型的元素,提高代码的可读性和安全性。 在引用中的示例代码中,List<String>定义了一个只能存储字符串类型元素的列表。在引用中的示例代码中,Collection<String>和Collection<Integer>分别定义了只能存储字符串类型和整数类型元素的集合。使用泛型通配符可以增加集合的灵活性。比如在coll.removeAll(c)方法中,传入的Collection对象的泛型可以是任意类型。另外,泛型还可以应用于Map集合,如引用中的示例代码中,Set<Map.Entry<String,String>>定义了只能存储键值对类型为String的元素的集合。 综上所述,Java集合框架中的Map和泛型可以一起使用,通过泛型可以指定集合中存储的元素类型,增加代码的可读性和类型安全性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [java基础中的--------Map+泛型](https://blog.csdn.net/liutaiwu/article/details/107915445)[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^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值