集合-List/Map/Entry/Set/Iterator

2020-01-20  本文已影响0人  chrisghb

List

List<Integer> list = List.of(1, 2, 5);

但是List.of()方法不接受null值,如果传入null,会抛出NullPointerException异常。

1.在末尾添加一个元素:void add(E e)
2.在指定索引添加一个元素:void add(int index, E e)
3.删除指定索引的元素:int remove(int index)
4.删除某个元素:int remove(Object e)
5.获取指定索引的元素:E get(int index)
6.设置list中某个位置的元素:E set(int index, E e)
6.获取链表大小(包含元素的个数):int size()

1.只要实现了Iterable接口的集合类都可以直接用for each循环来遍历,Java编译器会自动把for each循环变成Iterator的调用。
Iterator对象有两个方法:boolean hasNext()判断是否有下一个元素,E next()返回下一个元素。

for (String s : list) {
  System.out.println(s);
}

2.转为stream集合从而进行聚合操作

// 初始化
List<String> strings = Arrays.asList("abc", "", "bc", "efg", "abcd","", "jkl");
List<String> filtered = strings.stream().filter(string -> !string.isEmpty()).collect(Collectors.toList()).forEach(System.out::println);

1.List转Array

teger[] array = list.toArray(Integer[]::new)

2.Array转List

Integer[] array = { 1, 2, 3 };
List<Integer> list = List.of(array);

注意:如果用Arrays.asList()方法返回的对象是Arrays的内部类,对list的操作仍然反映在原数组上,因此这个list是定长的,不支持add、remove操作;

List集合的contains() ,indexOf的比较

List集合去重的一些方法(常规遍历、Set去重、java8 )stream去重、重写equals和hashCode方法)

Map

java笔记--Map的用法

1.对Map来说,要遍历key可以使用for each循环遍历Map实例的keySet()方法返回的Set集合,它包含不重复的key的集合:

for (String key : map.keySet()) {
            Integer value = map.get(key);
            System.out.println(key + " = " + value);
}

2.同时遍历key和value可以使用for each循环遍历Map对象的entrySet()集合,它包含每一个key-value映射:

for (Map.Entry<String, Integer> entry : map.entrySet()) {
            String key = entry.getKey();
            Integer value = entry.getValue();
            System.out.println(key + " = " + value);
}

Entry

Map.Entry是Map声明的一个内部接口,此接口为泛型,定义为Entry<K,V>。它表示Map中的一个实体(一个key-value对)。接口中有getKey(),getValue方法。

  Map<String, String> map = new HashMap<String, String>();    
  map.put("key1", "value1");    
  map.put("key2", "value2");    
  map.put("key3", "value3");    
  //第一种:普遍使用,二次取值    
  System.out.println("通过Map.keySet遍历key和value:");    
  for (String key : map.keySet()) {    
   System.out.println("key= "+ key + " and value= " + map.get(key));    
  }   
  //第二种    
  System.out.println("通过Map.entrySet使用iterator遍历key和value:");    
  Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();    
  while (it.hasNext()) {    
   Map.Entry<String, String> entry = it.next();    
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());    
  }    
  //第三种:推荐,尤其是容量大时</span>    
  System.out.println("通过Map.entrySet遍历key和value");    
  for (Map.Entry<String, String> entry : map.entrySet()) {    
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());    
  }    
  //第四种    
  System.out.println("通过Map.values()遍历所有的value,但不能遍历key");    
  for (String v : map.values()) {    
   System.out.println("value= " + v);    
  }

Set

1.将元素添加进Set<E>:boolean add(E e)
2.将元素从Set<E>删除:boolean remove(Object e)
3.判断是否包含元素:boolean contains(Object e)

HashSet<String> set = new HashSet<>();
for (int i = 0; i < arr.length; i++) {
            set.add(arr[i]);
}

1.HashSet是无序的,因为它实现了Set接口,并没有实现SortedSet接口;
2.TreeSet是有序的,因为它实现了SortedSet接口。

Iterator

我们把这种通过Iterator对象遍历集合的模式称为迭代器。
实际上,Java编译器并不知道如何遍历List。编译器把for each循环通过Iterator改写为了普通的for循环:

for (Iterator<String> it = list.iterator(); it.hasNext(); ) {
     String s = it.next();
     System.out.println(s);
}

对比集合的STREAM().FOREACH()和FOREACH()
增强for循环和stream.forEach()遍历集合时的跳出操作

上一篇 下一篇

猜你喜欢

热点阅读