Map集合

简介: Map集合
  • map集合的特点和遍历方式
  • HashMap和hashtable的区别
  • map集合字符串出现的次数
  • map集合泛型
  • 工具类


map集合的特点和遍历方式

1.增删改查

2.键值对形式存在

3.key可以为空

package com.zhulinjun;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class mdemo1 {
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);
  System.out.println(map);
  //删除
  Object remove=map.remove("b");
  System.out.println(map);//{a=1, c=3, d=4}
  //修改
  map.put("c", 32);
  System.out.println(map);//{a=1, c=3, d=4}  {a=1, c=32, d=4}
  //查询
  System.out.println(map.get("c"));
  //查询所有=======遍历方式
  //1.拿到map集合中的所有key
  Set keys=map.keySet();
  for (Object key : keys) {
    System.out.println("键:"+key+";值"+map.get(key));
  }
  //2.拿到映射关系
  Set<Entry<String, Integer>> entrySet = map.entrySet();
  for (Entry<String, Integer> entry : entrySet) {
    System.out.println("键:"+entry.getKey()+";值"+entry.getValue());
  }
}
}

HashMap和hashtable的区别

1.hashtable线程是安全的(synchronized)

map集合字符串出现的次数

package com.zhulinjun;
import java.util.HashMap;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
public class mdemo2 {
public static void main(String[] args) {
  String s="arghrhtyuyitdghytjtjysfhhghjyjffgnhggjmsakk";
  /**
   * 实现思路:
       1.做字符串切割,得到一个字符数组
       2.接下来遍历,拿到单个字符
       3.如果该字符没有出现过,即value值为null,那么该字符为KEY,值初始化为1
       4.如果已经出现过,拿到原来的值+1
       debugger的使用,调试代码
       1.打断点
       2.采用debug的方式运行程序
       3.进入调试窗口,左上方有一个step over调试箭头,快捷键F6
       4.接下来可以通过F6调试当前程序对应的每一个变量值
   */
  char[] arr = s.toCharArray();
  Map<Character, Integer> map=new HashMap<>();
  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());
  }
}
}

map集合泛型

1.泛型的作用:之前,不健壮的代码,会在运行时才会把错误暴露出来;之后,将潜在的问题暴露出来,早预防早治疗。将运行期出现的异常转换为编译期的错误。

2.泛型类

3.泛型方法

package com.zhulinjun;
import java.util.List;
public class mdemo3 {
}
//创建泛型类
class UserDao extends BaseDao{
}
class BaseDao<T>{
  void add(T t) {}
    void del(T t) {}
    void edit(T t) {}
    List<T> list(T t){
      return null;
    }
}
//泛型方法(当类不是泛型类又想添加方法)
class Result{
  <T>void del(T t){}
}

集合框架工具类

package com.zhulinjun;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;
public class mdemo4 {
  public static void main(String[] args) {
//  1.集合之间的互相转换:数组转换成集合,本质上依然是一个数组,长度是不可变的,不可增加元素;
//                                             集合与数组所具备的方法是不一样的,如对数组而言,就有判断内部包含哪个元素;
  String[] arr= {"a","b","c","d"};//数组转集合
    List<String> list = Arrays.asList(arr); 
//  Object[] array = list.toArray();  集合转数组
}
}
class mdemo5{
  public static void main(String[] args) {
//      对于工具类其他方法的应用
    List<String> list = new ArrayList<>();
    list.add("b");
    list.add("c");
    list.add("a");
    System.out.println(list);//[b, c, a]
    Collections.sort(list);
    System.out.println(list);//[a, b, c]
    //x,y指集合中的元素
    Collections.sort(list, (x,y) -> y.compareTo(x));
    System.out.println(list);//[c, b, a]
    System.out.println("==========================================");
    List<Per> list1=new ArrayList<>();
    list1.add(new Per("b", 16));
    list1.add(new Per("c", 18));
    list1.add(new Per("a", 19));
    System.out.println(list);//[c, b, a]
    Collections.sort(list);
    System.out.println(list);//[a, b, c]
  }
}
class Per 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;
  }
  @Override
  public String toString() {
    return "Person [name=" + name + ", age=" + age + "]";
  }
  public Per(String name, int age) {
    super();
    this.name = name;
    this.age = age;
  }
  public Per() {
    super();
    // TODO Auto-generated constructor stub
  }
  @Override
  public int compareTo(Person o) {
    // TODO Auto-generated method stub
    return o.getName().compareTo(this.getName());
  }
目录
相关文章
|
6月前
|
Dart
Dart之集合详解(List、Set、Map)
Dart之集合详解(List、Set、Map)
|
6月前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
83 3
|
3月前
|
Go 定位技术 索引
Go 语言Map(集合) | 19
Go 语言Map(集合) | 19
|
3月前
|
存储 前端开发 API
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
该文章详细介绍了ES6中Set和Map数据结构的特性和使用方法,并探讨了它们在前端开发中的具体应用,包括如何利用这些数据结构来解决常见的编程问题。
ES6的Set和Map你都知道吗?一文了解集合和字典在前端中的应用
|
4月前
|
存储 安全 Java
java集合框架复习----(4)Map、List、set
这篇文章是Java集合框架的复习总结,重点介绍了Map集合的特点和HashMap的使用,以及Collections工具类的使用示例,同时回顾了List、Set和Map集合的概念和特点,以及Collection工具类的作用。
java集合框架复习----(4)Map、List、set
|
4月前
|
Java
【Java集合类面试二十二】、Map和Set有什么区别?
该CSDN博客文章讨论了Map和Set的区别,但提供的内容摘要并未直接解释这两种集合类型的差异。通常,Map是一种键值对集合,提供通过键快速检索值的能力,而Set是一个不允许重复元素的集合。
|
4月前
|
算法 Java 索引
【Java集合类面试四】、 描述一下Map put的过程
这篇文章详细描述了HashMap中put操作的过程,包括首次扩容、计算索引、插入数据以及链表转红黑树和可能的再次扩容。
【Java集合类面试四】、 描述一下Map put的过程
|
4月前
|
存储
|
4月前
|
安全 Java
【Java集合类面试五】、 如何得到一个线程安全的Map?
如何得到一个线程安全的Map的方法包括:使用Collections工具类将Map包装为线程安全,使用java.util.concurrent包下的ConcurrentHashMap,以及不推荐使用性能较差的Hashtable。
|
4月前
|
安全 Java
【Java集合类面试三】、Map接口有哪些实现类?
这篇文章介绍了Java中Map接口的几种常用实现类:HashMap、LinkedHashMap、TreeMap和ConcurrentHashMap,以及它们适用的不同场景和线程安全性。