当前位置:   article > 正文

J2EE基础(集合框架之Map集合)_for(char c:arr)

for(char c:arr)

目录

1、map集合的特点

2、map集合的遍历方式

3、常用实现HashMap

4、泛型

5、集合框架工具类


一、map集合的特点

        ①以键值对的形式存放数据:

  1. package com.zq.map;
  2. import java.util.HashMap;
  3. import java.util.Map;
  4. public class Demo1 {
  5. public static void main(String[] args) {
  6. Map<String,Integer> map=new HashMap<>();
  7. //增
  8. // V put(K key, V value);
  9. map.put("a", 1);
  10. map.put("b", 2);
  11. map.put("c", 3);
  12. map.put("d", 4);
  13. System.out.println("普通遍历"+map);
  14. }
  15. }

        结果:

         ②Map集合增删改

  1. package com.zq.map;
  2. import java.util.HashMap;
  3. import java.util.Map;
  4. public class Demo1 {
  5. public static void main(String[] args) {
  6. Map<String,Integer> map=new HashMap<>();
  7. //增
  8. // V put(K key, V value);
  9. map.put("a", 1);
  10. map.put("b", 2);
  11. map.put("c", 3);
  12. map.put("d", 4);
  13. System.out.println("增加结果:"+map);
  14. //删除
  15. Object obj = map.remove("b");
  16. //打印删除的值
  17. System.out.println(obj);
  18. System.out.println("删除后结果"+map);
  19. //修改 也是调用put方法
  20. map.put("c", 32);
  21. System.out.println("修改后结果"+map);
  22. }
  23. }

        结果:


二、map集合的遍历方式查询):

        ①拿到Key,再拿值:

  1. //1.先拿到map集合中所有key
  2. Set keyS = map.keySet();
  3. for (Object key : keyS) {
  4. System.out.println("键:"+key+";值:"+map.get(key));
  5. }

        结果:

        ②:拿到映射关系,键值都有了

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

        结果:


三、常用实现HashMap

        面试题1:统计各字符串出现的次数

       解决思路:
1.做字符串切割,得到一个字符串组
2.接下来遍历,拿到单个字符
3.如果该字符没有出现过,即value值为null,那么设置该字符为KEY(键)初始value值为1
4.如果已经出现过,拿到原来的值+1

        代码展示:

  1. package com.zq.map;
  2. import java.util.HashMap;
  3. import java.util.Map.Entry;
  4. import java.util.Set;
  5. public class Demo2 {
  6. public static void main(String[] args) {
  7. String s = "sdjsahdjshjdsdjsdiwjksjakjdsa";
  8. char[] arr = s.toCharArray();//分割字符串
  9. HashMap<Character, Integer> map = new HashMap<>();
  10. for (char c : arr) {
  11. Integer value = map.get(c);
  12. if (value == null) {
  13. map.put(c, 1);
  14. } else {
  15. map.put(c, value + 1);
  16. }
  17. }
  18. Set<Entry<Character, Integer>> entrySet = map.entrySet();
  19. for (Entry<Character, Integer> entry : entrySet) {
  20. System.out.println("键:" + entry.getKey() + ":值" + entry.getValue());
  21. }
  22. }
  23. }

         结果:

        需求1:按照按首字母排序

        分析:可以采用上次的TreeSet方式,我们在Map集合中也可以采用TreeMap

                Map<Character, Integer> map = new TreeMap<>() ;

          代码展示:

  1. package com.zq.map;
  2. import java.util.HashMap;
  3. import java.util.Map;
  4. import java.util.Map.Entry;
  5. import java.util.Set;
  6. import java.util.TreeMap;
  7. public class Demo2 {
  8. public static void main(String[] args) {
  9. String s = "sdjsahdjshjdsdjsdiwjksjakjdsa";
  10. char[] arr = s.toCharArray();
  11. Map<Character, Integer> map = new TreeMap<>() ;
  12. for (char c : arr) {
  13. Integer value = map.get(c);
  14. if (value == null) {
  15. map.put(c, 1);
  16. } else {
  17. map.put(c, value + 1);
  18. }
  19. }
  20. Set<Entry<Character, Integer>> entrySet = map.entrySet();
  21. for (Entry<Character, Integer> entry : entrySet) {
  22. System.out.println("键:" + entry.getKey() + ":值" + entry.getValue());
  23. }
  24. }
  25. }

        结果: 我们成功按照首字母进行了升序排序!

        注意:降序的话就改变一行代码:

                        Map<Character, Integer> map = new TreeMap<>((x,y) ->y-x);

         结果: 我们成功按照首字母进行了降序排序!

         需求1:按照按首字母排序

          代码展示:

  1. package com.zq.map;
  2. import java.util.ArrayList;
  3. import java.util.Comparator;
  4. import java.util.List;
  5. import java.util.Map;
  6. import java.util.Map.Entry;
  7. import java.util.TreeMap;
  8. public class Demo3 {
  9. public static void main(String[] args) {
  10. String s = "sdjsahdjshjdsdjsdiwjksjakjdsa";
  11. char[] arr = s.toCharArray();
  12. Map<Character, Integer> map = new TreeMap<>((x,y) ->y-x);
  13. for (char c : arr) {
  14. Integer value = map.get(c);
  15. if (value == null) {
  16. map.put(c, 1);
  17. } else {
  18. map.put(c, value + 1);
  19. }
  20. }
  21. //map.entrySet() 拿到映射关系
  22. List<Map.Entry<Character, Integer>> aa=new ArrayList<>(map.entrySet());
  23. //实现接口sort
  24. aa.sort(new Comparator<Map.Entry<Character, Integer>>() {
  25. //实现Comparator
  26. @Override
  27. public int compare(Entry<Character, Integer> o1, Entry<Character, Integer> o2) {
  28. return o1.getValue() - o2.getValue();
  29. }
  30. });
  31. //遍历
  32. for (Entry<Character, Integer> entry : aa) {
  33. System.out.println(entry);
  34. }
  35. }
  36. }

        结果: 我们成功按照字母出现次数进行了升序排序!


四、泛型

 泛型:就是一种不确定的数据类型。
        比如:ArrayList<E> E就是泛型。 这种不确定的数据类型需要在使用这个类的时候才能够确定出来。
        泛型可以省略,如果省略,默认泛型是Object类型。
        泛型的好处:
                1. 省略了强转的代码。
                2. 可以把运行时的问题提前暴露到编译时期。

        泛型之前:不健状代码,会在运行时才会把错误暴露出来

        泛型之后:将潜在的问题暴露出来,早预防早治疗 将运行期的出现的异常转换为编译期的错误

        不加泛型:不会出现编译报错!但是运行有问题

  1. package com.zq.map;
  2. import java.util.HashSet;
  3. import java.util.Set;
  4. public class Demo4 {
  5. public static void main(String[] args) {
  6. Set set = new HashSet<>();
  7. set.add(1);
  8. set.add(2);
  9. set.add(3);
  10. set.add(4);
  11. set.add(5);
  12. for (Object object : set) {
  13. if(Integer.valueOf(object.toString()) % 2 == 0) {
  14. System.out.println(object);
  15. }
  16. set.remove(object);
  17. }
  18. }
  19. }

         加泛型后:编译直接报错,更加直观

        注意:泛型可以运用在做项目时,一些重复性的方法进行多个类的使用时,添加泛型进行编码效率的提高!


五、集合框架工具类

        5.1Collection

               面试题2:分析题目,问是否出现问题?

  1. String[] arr={"a","b","c","d"};
  2. List<String> list = Arrays.asList(arr);
  3. // Object[] array = list.toArray();
  4. list.add("e");
  5. // java.lang.UnsupportedOperationException
  6. System.out.println(list.size());

              分析:其实这里有很容易错误的题,我们一般都以为数组转成集合然后再扩大了存储空间,加了有个e,这似乎没有任何问题,但是我们要记住数组转成集合,本质上依然是一个数组,长度是不可变的

        结果为:

         ①:基本数据类型排序:

  1. package com.zq.map;
  2. import java.util.ArrayList;
  3. import java.util.Collections;
  4. import java.util.List;
  5. public class Demo6 {
  6. public static void main(String[] args) {
  7. List<String> list = new ArrayList<String>();
  8. list.add("b");
  9. list.add("a");
  10. list.add("c");
  11. list.add("d");
  12. System.out.println("默认无序"+list);
  13. //将list集合进行排序 升序
  14. Collections.sort(list);
  15. System.out.println("升序"+list);
  16. //降序 这里的x跟y指的是集合里的元素
  17. Collections.sort(list, (x,y) -> y.compareTo(x));
  18. System.out.println("降序"+list);
  19. }
  20. }

        结果为:  

         ②对象等其他数据类型排序:

  1. package com.zq.map;
  2. import java.util.ArrayList;
  3. import java.util.Arrays;
  4. import java.util.Collections;
  5. import java.util.List;
  6. public class Demo6 {
  7. public static void main(String[] args) {
  8. List<Preson> list = new ArrayList<Preson>();
  9. list.add(new Preson("b", 12));
  10. list.add(new Preson("s", 14));
  11. list.add(new Preson("k", 19));
  12. list.add(new Preson("a", 18));
  13. System.out.println("排序前 :"+list);
  14. //实现接口的做法
  15. Collections.sort(list);
  16. System.out.println("实现接口排序后:"+list);
  17. //不实现接口的做法
  18. Collections.sort(list,(x,y)->x.getName().compareTo(y.getName()));
  19. System.out.println("不实现接口排序:"+list);
  20. Integer[] arr= {3,2,4,6,8,1};
  21. Arrays.sort(arr);
  22. System.out.println("打印地址:"+arr);
  23. System.out.println("默认升序: "+Arrays.toString(arr));
  24. Arrays.sort(arr,(x,y)-> y-x);
  25. System.out.println("降序:"+Arrays.toString(arr));
  26. }
  27. }
  28. class Preson implements Comparable<Preson>{
  29. private String name;
  30. private int age;
  31. public String getName() {
  32. return name;
  33. }
  34. public void setName(String name) {
  35. this.name = name;
  36. }
  37. public int getAge() {
  38. return age;
  39. }
  40. public void setAge(int age) {
  41. this.age = age;
  42. }
  43. public Preson() {
  44. // TODO Auto-generated constructor stub
  45. }
  46. public Preson(String name, int age) {
  47. super();
  48. this.name = name;
  49. this.age = age;
  50. }
  51. @Override
  52. public String toString() {
  53. return "Preson [name=" + name + ", age=" + age + "]";
  54. }
  55. //实现方法
  56. @Override
  57. public int compareTo(Preson o) {
  58. return o.getName().compareTo(this.getName());
  59. }
  60. }

        结果为:  

        5.2Arrays

        ①集合转换组:toArray

  1. String[] str = {"a","b","c","d","e"};
  2. List<String> list = Arrays.asList(str);
  3. //数组转为集合
  4. Object[] array = list.toArray();

        ②数组转集合:asList

  1. String[] str = {"a","b","c","d","e"};
  2. List<String> list = Arrays.asList(str);
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Cpp五条/article/detail/441424
推荐阅读
相关标签
  

闽ICP备14008679号