目录
一,集合特点
① 基础操作
Ⅰ,增
Ⅱ,删
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);
}
}