集合框架之Map集合

目录

一,集合特点

        ① 基础操作

                Ⅰ,增

                Ⅱ,删

                Ⅲ,改

                Ⅳ,查

        ②  键值对形式存在

        ③  key可以为空

二,遍历方式

        ① entrySet

        ② keySet

三,常用实现类HashMap

        实例:统计字符串各字母出现的次数

四,泛型

        ① 作用

                ⅰ,将运行时产生的异常转换为编译期的错误

                ⅱ,提高代码的健壮性

        ② 泛型集合(简单的了解)

        ③ 泛型方法(简单的了解)

五,集合框架工具类

         ① Collection

               ⅰ, 排序

               ⅱ,集合转数组:toArray

         ② Arrays

                ⅰ,toString

                ⅱ,asList

                 iii,  sort


一,集合特点

        ① 基础操作

                Ⅰ,增

                Ⅱ,删

              map集合删除用 map.remove("键");

                Ⅲ,改

                map集合的修改也是调用put方法  即 map.put(键,值) 

                Ⅳ,查

        查,有两种方式 1,拿到键(key),再拿值(value). 2,拿到映射关系,键值就都有了

 完整代码:

package com.ruojuan.cc;

import java.util.HashMap;
import java.util.Hashtable;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

/**
 * @author liuruojuan
 *
 * 时间:2022年6月9日上午11:06:55
 */
public class Dome1 {
	public static void main(String[] args) {

		
		Map map = new HashMap<>();
		//增加
		map.put("a", 1);
		//V put(K key, V value);
		//map.put(null, 2);
		map.put("b", 2);
		map.put("c", 3);
		map.put("d", 4);
		System.out.println(map);
		System.out.println("````````````删除的值``````````````````");
		Object remove = map.remove("b");
		System.out.println(remove);
		System.out.println("`````````````删除后`````````````````");
		System.out.println(map);
		System.out.println("``````````````修改后````````````````");
		//修改 也是调用put方法
		map.put("c", 32);
		//查询
		System.out.println(map.get("c"));//查询单个
		System.out.println("``````````````````````````````");
		//查询所有
		Set keys = map.keySet();
		for (Object key : keys) {
			System.out.println("键:"+key+" 值:"+map.get(key));
		}
		System.out.println("``````````````````````````````");

		//2.拿到映射关系
		Set<Entry<String, Integer>> entrySet = map.entrySet();
		for (Entry<String, Integer> entry : entrySet) {
			System.out.println("键:"+entry.getKey()+" 值:"+entry.getValue());
		}
		
		
		
	}
}

        ②  键值对形式存在

            map集合是以键值对的形式存在的

键值对形式

        ③  key可以为空

二,遍历方式

        ① entrySet

                

 完整代码:

package com.ruojuan.cc;

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

public class Dome6 {
	
	public static void main(String[] args) {
		
		Map<String,Integer> map = new HashMap<>();
		map.put("a", 1);
		map.put("b", 2);
		map.put("c", 3);
		map.put("d", 4);
		//entrySet
		Set<Entry<String, Integer>> entrySet = map.entrySet();
		for (Entry<String, Integer> entry : entrySet) {
			System.out.println("键:"+entry.getKey()+" 值:"+entry.getValue());
		}

		
	}
	
}

        ② keySet

完整代码:

package com.ruojuan.cc;

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

public class Dome6 {
	
	public static void main(String[] args) {
		
		Map map = new HashMap<>();
		map.put("a", 1);
		map.put("b", 2);
		map.put("c", 3);
		map.put("d", 4);
		//keySet
		Set keys = map.keySet();
		for (Object key : keys) {
			System.out.println("键:"+key+" 值:"+map.get(key));
		}

		
	}
	
}

三,常用实现类HashMap

        实例:统计字符串各字母出现的次数

        实现思路:
              1.做字符串切割,得到一个字符数组
              2.接下来遍历,拿到单个字符
              3.如果该字符串没出现过,即value值为null,那么该字符为key,值初始化为1
              4.如果已经出现,拿到原来的值+1 

 图解:

 完整代码:

package com.ruojuan.cc;

import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.TreeMap;

public class Dome6 {
	
	public static void main(String[] args) {
		
		String s = "adskdlkircciohfhmjhduaidlujfdsjdksahd";
		
		char[] arr = s.toCharArray();
		Map<Character, Integer> map = new TreeMap<>();
		for (char c : arr) {
			Integer value = map.get(c);
			if(value == null) {
				map.put(c, 1);
			}
			else {
				map.put(c, value+1);
			}
		}
		
		Set<Entry<Character, Integer>> entrySet = map.entrySet();
		for (Entry<Character, Integer> entry : entrySet) {
			System.out.println(entry.getKey()+": "+ entry.getValue());
		}
		


		
	}
	
}

四,泛型

        ① 作用

                ⅰ,将运行时产生的异常转换为编译期的错误

                ⅱ,提高代码的健壮性

   ② 泛型集合(简单的了解)

常规代码:

 

 泛型集合:

完整代码:

package com.ruojuan.cc;

import java.util.HashSet;
import java.util.Set;

public class Dome6 {
	
	public static void main(String[] args) {
		
		Set<Integer> set = new HashSet<>();
		set.add(1);
		set.add(2);
		set.add(3);
		set.add(4);
		set.add(5);
		set.add(6);
		for (Object obj : set) {
			if(Integer.valueOf(obj.toString())%2==0) {
				System.out.println(obj);
			}
		}

		
	}
	
}

   

        ③ 泛型方法(简单的了解)

如果在调用方法的时候的参数类型不确定,或者方法的返回值类型不确定,那么可以将这个方法定义为泛型方法。一般在工具类中会经常使用到。

五,集合框架工具类

         ① Collection

               ⅰ, 排序

               ⅱ,集合转数组:toArray

这串代码报错的原因是:

 集合间的互相转换:
    1.数组转成集合,本质上依然是一个数组,长度是不可变得
    2.集合与数组所具备的方法是不一样的,对于数组而言,就没有判断内部包含哪个元素

完整代码:

package com.ruojuan.cc;

import java.util.Arrays;
import java.util.List;

public class Dome6 {
	
	public static void main(String[] args) {
		
		String [] arr = {"a","b","c","d","e"};
		List<String> list = Arrays.asList(arr);
		list.add("f");
		System.out.println(list.size());
		
		
	}
	
}

         ② Arrays

                ⅰ,toString

                ⅱ,asList

                 iii,  sort

代码:

package com.ruojuan.cc;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;

/**
 * 对于工具类其他方法的应用
 * sort
 * tostring
 * @author liuruojuan
 *
 * 时间:2022年6月9日下午2:28:35
 */
public class Dome5 {
	public static void main(String[] args) {
//		List<String> list = new ArrayList<>();
//		list.add("q");
//		list.add("t");
//		list.add("s");
//		list.add("g");
//		list.add("w");
//		System.out.println(list);
//		System.out.println("----------------");
//		Collections.sort(list);
//		System.out.println(list);
//		System.out.println("----------------");
//		//这里x,y指的是集合中的元素
//		Collections.sort(list,(x,y) -> y.compareTo(x));
//		System.out.println(list);
		
		
		List<Person> list = new ArrayList<>();
		list.add(new Person("b",13));
		list.add(new Person("e",16));
		list.add(new Person("a",12));
		list.add(new Person("d",15));
		list.add(new Person("c",14));
		System.out.println(list);
		System.out.println("----------------");
		//Collections.sort(list);
		Collections.sort(list,(x,y) -> x.getName().compareTo(y.getName()));
		System.out.println(list);
		
		Integer[] arr = {4,1,3,5,4,8};
		//Arrays.sort(arr);
		//System.out.println(Arrays.toString(arr));
		
		Arrays.sort(arr,(x,y) ->y -x);
		System.out.println(Arrays.toString(arr));

		
	}
}
class Person implements Comparable<Person>{
	private String name;
	private int 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;
	}
	public Person() {
		// TODO Auto-generated constructor stub
	}
	public Person(String name, int age) {
		super();
		this.name = name;
		this.age = age;
	}
	@Override
	public String toString() {
		return "Person [name=" + name + ", age=" + age + "]";
	}
	@Override
	public int compareTo(Person o) {
		return o.getName().compareTo(this.name);
	}
	
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
回答: 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 ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值