目录
1. ArrayList
Java ArrayList 常用方法
|
package com.test;
import java.util.ArrayList;
public class ArrayListTest {
public static void main(String[] args) {
ArrayList<String> sites = new ArrayList<String>();
//添加元素
sites.add("Google");
sites.add("Runoob");
sites.add("Taobao");
sites.add("Weibo");
System.out.println(sites);//[Google, Runoob, Taobao, Weibo]
// get -- 访问第二个元素(ArrayList的添加是有顺序的)
System.out.println(sites.get(1));//Runoob
// set -- 第一个参数为索引位置,第二个为要修改的值
sites.set(2, "Wiki");
System.out.println(sites);//[Google, Runoob, Wiki, Weibo]
// remove -- 删除第四个元素
sites.remove(3);
System.out.println(sites);//[Google, Runoob, Wiki]
// size -- 计算 ArrayList 中的元素数量
System.out.println(sites.size());//3
}
}
2. LinkedList
LinkedList常用方法
方法 | 描述 |
---|---|
public boolean add(E e) | 链表末尾添加元素,返回是否成功,成功为 true,失败为 false。 |
public void add(int index, E element) | 向指定位置插入元素。 |
public boolean addAll(Collection c) | 将一个集合的所有元素添加到链表后面,返回是否成功,成功为 true,失败为 false。 |
public boolean addAll(int index, Collection c) | 将一个集合的所有元素添加到链表的指定位置后面,返回是否成功,成功为 true,失败为 false。 |
public void addFirst(E e) | 元素添加到头部。 |
public void addLast(E e) | 元素添加到尾部。 |
public boolean offer(E e) | 向链表末尾添加元素,返回是否成功,成功为 true,失败为 false。 |
public boolean offerFirst(E e) | 头部插入元素,返回是否成功,成功为 true,失败为 false。 |
public boolean offerLast(E e) | 尾部插入元素,返回是否成功,成功为 true,失败为 false。 |
public void clear() | 清空链表。 |
public E removeFirst() | 删除并返回第一个元素。 |
public E removeLast() | 删除并返回最后一个元素。 |
public boolean remove(Object o) | 删除某一元素,返回是否成功,成功为 true,失败为 false。 |
public E remove(int index) | 删除指定位置的元素。 |
public E poll() | 删除并返回第一个元素。 |
public E remove() | 删除并返回第一个元素。 |
public boolean contains(Object o) | 判断是否含有某一元素。 |
public E get(int index) | 返回指定位置的元素。 |
public E getFirst() | 返回第一个元素。 |
public E getLast() | 返回最后一个元素。 |
public int indexOf(Object o) | 查找指定元素从前往后第一次出现的索引。 |
public int lastIndexOf(Object o) | 查找指定元素最后一次出现的索引。 |
public E peek() | 返回第一个元素。 |
public E element() | 返回第一个元素。 |
public E peekFirst() | 返回头部元素。 |
public E peekLast() | 返回尾部元素。 |
public E set(int index, E element) | 设置指定位置的元素。 |
public Object clone() | 克隆该列表。 |
public Iterator descendingIterator() | 返回倒序迭代器。 |
public int size() | 返回链表元素个数。 |
public ListIterator listIterator(int index) | 返回从指定位置开始到末尾的迭代器。 |
public Object[] toArray() | 返回一个由链表元素组成的数组。 |
public T[] toArray(T[] a) | 返回一个由链表元素转换类型而成的数组。 |
package com.test;
import java.util.LinkedList;
public class LinkedListTest {
public static void main(String[] args) {
//采用双向链表结构,增删快,查找满
LinkedList<String> sites = new LinkedList<String>();
sites.add("Google");
sites.add("Runoob");
sites.add("Taobao");
sites.add("Weibo");
System.out.println(sites);//[Google, Runoob, Taobao, Weibo]
// 使用 addFirst() 在头部添加元素(removeFirst()删除头部元素)
sites.addFirst("Wiki");
System.out.println(sites);//[Wiki, Google, Runoob, Taobao, Weibo]
// 使用 addLast() 在尾部添加元素(removeLast()删除尾部元素)
sites.addLast("Timi");
System.out.println(sites);//[Wiki, Google, Runoob, Taobao, Weibo, Timi]
}
}
两者区别及使用情况
与 ArrayList 相比,LinkedList 的增加和删除的操作效率更高,而查找和修改的操作效率较低。
以下情况使用 ArrayList :
- 频繁访问列表中的某一个元素。
- 只需要在列表末尾进行添加和删除元素操作。
以下情况使用 LinkedList :
- 你需要通过循环迭代来访问列表中的某些元素。
- 需要频繁的在列表开头、中间、末尾等位置进行添加和删除元素操作。
3. Hashset(散列表)
HashSet 基于 HashMap 来实现的,是一个不允许有重复元素的集合。
HashSet 允许有 null 值。
HashSet 是无序的,即不会记录插入的顺序。
HashSet 不是线程安全的, 如果多个线程尝试同时修改 HashSet,则最终结果是不确定的
package com.test;
import java.util.HashSet;
public class HashSetTest {
// 引入 HashSet 类
public static void main(String[] args) {
HashSet<String> sites = new HashSet<String>();
sites.add("Google");
sites.add("Runoob");
sites.add("Taobao");
sites.add("Zhihu");
sites.add("Runoob"); // 重复的元素不会被添加
//无序的存储元素
System.out.println(sites);//[Google, Runoob, Zhihu, Taobao]
//判断元素是否存在
System.out.println(sites.contains("Taobao"));//true
// 删除元素
sites.remove("Taobao");
System.out.println(sites);//[Google, Runoob, Zhihu]
//计算大小
System.out.println(sites.size());//3
//清空元素
sites.clear();
System.out.println(sites);//[]
}
}
4. HashMap
Map 是以Key-Value键值对存储
Java HashMap 方法常用方法列表如下
方法 | 描述 |
---|---|
clear() | 删除 hashMap 中的所有键/值对 |
clone() | 复制一份 hashMap |
isEmpty() | 判断 hashMap 是否为空 |
size() | 计算 hashMap 中键/值对的数量 |
put() | 将键/值对添加到 hashMap 中 |
putAll() | 将所有键/值对添加到 hashMap 中 |
putIfAbsent() | 如果 hashMap 中不存在指定的键,则将指定的键/值对插入到 hashMap 中。 |
remove() | 删除 hashMap 中指定键 key 的映射关系 |
containsKey() | 检查 hashMap 中是否存在指定的 key 对应的映射关系。 |
containsValue() | 检查 hashMap 中是否存在指定的 value 对应的映射关系。 |
replace() | 替换 hashMap 中是指定的 key 对应的 value。 |
replaceAll() | 将 hashMap 中的所有映射关系替换成给定的函数所执行的结果。 |
get() | 获取指定 key 对应对 value |
getOrDefault() | 获取指定 key 对应对 value,如果找不到 key ,则返回设置的默认值 |
forEach() | 对 hashMap 中的每个映射执行指定的操作。 |
entrySet() | 返回 hashMap 中所有映射项的集合集合视图。 |
keySet() | 返回 hashMap 中所有 key 组成的集合视图。 |
values() | 返回 hashMap 中存在的所有 value 值。 |
merge() | 添加键值对到 hashMap 中 |
compute() | 对 hashMap 中指定 key 的值进行重新计算 |
computeIfAbsent() | 对 hashMap 中指定 key 的值进行重新计算,如果不存在这个 key,则添加到 hasMap 中 |
computeIfPresent() | 对 hashMap 中指定 key 的值进行重新计算,前提是该 key 存在于 hashMap 中。 |
package com.test;
// 引入 HashMap 类
import java.util.HashMap;
public class HashMapTest {
public static void main(String[] args) {
// 创建 HashMap 对象 Sites
HashMap<Integer, String> Sites = new HashMap<Integer, String>();
// 添加键值对
Sites.put(1, "Google");
Sites.put(2, "Runoob");
Sites.put(3, "Taobao");
Sites.put(4, "Zhihu");
//key如果已经存在则会覆盖旧值
Sites.put(4, "jingdong");
System.out.println(Sites);//{1=Google, 2=Runoob, 3=Taobao, 4=jingdong}
// 通过key来得到value
System.out.println(Sites.get(3));//Taobao
//根据key 删除值
Sites.remove(4);
System.out.println(Sites);//{1=Google, 2=Runoob, 3=Taobao}
//清楚所有元素
Sites.clear();
System.out.println(Sites);//{}
//计算Map大小
System.out.println(Sites.size());//0
}
}