List 汇合
java.util.List 接口 extends Collection 接口
List 接口的特点:
- 有序的汇合,存储元素和取出元素的程序是统一的
- 有索引,蕴含了一些带索引的办法
- 容许存储反复的元素
List 接口中带索引的办法(特有)
- public void add(int index, E element); 将指定的元素,增加到该汇合中的指定地位上。
- public E get(int index); 返回汇合中指定地位的元素。
- public E remove(int index); 移除列表中指定地位的元素,返回的是被移除的元素。
- public E set(int index, E element); 用指定元素替换汇合中指定地位的元素,返回值 更新前的元素。
留神:
操作索引的时候,肯定要避免索引越界异样。
public static void main(String[] args) {
// 创立一个 List 汇合对象,多态
List<String> list = new ArrayList<>();
// 应用 add 办法往汇合里增加元素
list.add("a");
list.add("b");
list.add("c");
list.add("d");
list.add("a");
System.out.println(list);
// public void add(int index, E element); 将指定的元素,增加到该汇合中的指定地位上。// 在 c 和 d 之间增加 DNA
list.add(3, "DNA");
System.out.println(list);
//public E remove(int index); 移除列表中指定地位的元素,返回的是被移除的元素。// 移除 c 元素
String removeE = list.remove(2);
System.out.println("被移除的元素:" + removeE);
System.out.println(list);
//public E set(int index, E element); 用指定元素替换汇合中指定地位的元素,返回值 更新前的元素。// 把最初一个 a 替换成 A
String setE = list.set(4, "A");
System.out.println("被替换的元素:" + setE);
System.out.println(list);
//List 汇合遍历有三种形式
// 应用一般的 for 循环
for (int i = 0; i < list.size(); i++) {//public E get(int index); 返回汇合中指定地位的元素。String s = list.get(i);
System.out.println(s);
}
System.out.println("--------------------");
// 应用迭代器
Iterator<String> it = list.iterator();
while (it.hasNext()) {String str = it.next();
System.out.println(str);
}
System.out.println("--------------------");
// 应用加强 for
for (String s : list) {System.out.println(s);
}
}
-----------------------------------------------------------------------------------------------------------------
[a, b, c, d, a]
[a, b, c, DNA, d, a]
被移除的元素:c
[a, b, DNA, d, a]
被替换的元素:a
[a, b, DNA, d, A]
a
b
DNA
d
A
--------------------
a
b
DNA
d
A
--------------------
a
b
DNA
d
A
LinkedList
java.util.LinkedList 汇合 implements List 接口
LinkedList 汇合的特点:
1. 底层是一个链表构造:查问慢,增删快。
2. 外面蕴含了大量操作首尾元素的办法。
留神:应用 LinkedList 汇合特有的办法,不能应用多态
常见办法:
- public void addFirst(E e) 将指定元素插入此列表的结尾。
- public void addLast(E e) 将指定元素增加到此列表的结尾。
- public void push(E e) 将元素推入此列表所示意的堆栈。
- public E getFirst() 返回此列表的第一个元素。
- public E getLast() 返回此列表的最初一个元素。
- public E removeFirst() 移除并返回此列表的第一个元素。
- public E removeLast() 移除并返回此列表的最初一个元素。
- public E pop() 从此列表所示意的堆栈处弹出一个元素。
- public boolean isEmpty() 如果列表不蕴含元素,则返回 true。
public static void main(String[] args) {show01();
}
/*
* - public void addFirst(E e) 将指定元素插入此列表的结尾。* - public void addLast(E e) 将指定元素增加到此列表的结尾。* - public void push(E e) 将元素推入此列表所示意的堆栈。此办法等效于 addFirst(E e)
*/
private static void show01() {
// 创立 linkedlist 对象
LinkedList<String> linked = new LinkedList<>();
// 应用 add 办法往汇合中增加元素
linked.add("a");
linked.add("b");
linked.add("c");
System.out.println(linked);
// public void addFirst(E e) 将指定元素插入此列表的结尾。linked.addFirst("www");
linked.push("com");// 等效于 addFirst(E e)
System.out.println(linked);
// public void addLast(E e) 将指定元素增加到此列表的结尾。linked.addLast("cn");// 等效于 add 办法
System.out.println(linked);
System.out.println("----------------------");
show02();}
/*
* - public E getFirst() 返回此列表的第一个元素。* - public E getLast() 返回此列表的最初一个元素。*/
private static void show02() {
// 创立 linkedlist 对象
LinkedList<String> linked = new LinkedList<>();
// 应用 add 办法往汇合中增加元素
linked.add("a");
linked.add("b");
linked.add("c");
System.out.println(linked);
linked.clear();
//public boolean isEmpty() 如果列表不蕴含元素,则返回 true。if (!linked.isEmpty()) {String first = linked.getFirst();
System.out.println(first);
String last = linked.getLast();
System.out.println(last);
}
System.out.println("---------");
show03();}
/*
* - public E removeFirst() 移除并返回此列表的第一个元素。- public E removeLast() 移除并返回此列表的最初一个元素。- public E pop() 从此列表所示意的堆栈处弹出一个元素。相当于 removeFirst()
*/
private static void show03() {
// 创立 linkedlist 对象
LinkedList<String> linked = new LinkedList<>();
// 应用 add 办法往汇合中增加元素
linked.add("a");
linked.add("b");
linked.add("c");
//String first = linked.removeFirst();
String first = linked.pop();
System.out.println("被移除的第一个元素是" + first);
System.out.println(linked);
String last = linked.removeLast();
System.out.println("被移除的最初一个元素是" + last);
System.out.println(linked);
}
-----------------------------------------------------------------------------------------------------------------
[a, b, c]
[com, www, a, b, c]
[com, www, a, b, c, cn]
----------------------
[a, b, c]
---------
被移除的第一个元素是 a
[b, c]
被移除的最初一个元素是 c
[b]
HashSet 汇合
java.util.Set 接口 extends Collection 接口
Set 接口的特点:
不容许存储反复的元素。
没有索引,没有带索引的办法,也不能应用一般的 for 循环遍历。
java.util.HashSet 汇合 implements Set 接口
HashSet 特点:
- 不容许存储反复的元素。
- 没有索引,没有带索引的办法,也不能应用一般的 for 循环遍历。
- 是一个无序的汇合,存储元素和取出元素有可能不统一。
- 底层是一个哈希表构造(查问速度十分快)。
public static void main(String[] args) {Set<Integer> set = new HashSet<>();
// 应用 add 办法往汇合中增加元素
set.add(1);
set.add(3);
set.add(2);
set.add(1);
// 应用迭代器遍历 set 汇合
Iterator<Integer> it = set.iterator();
while (it.hasNext()) {Integer nnn = it.next();
System.out.println(nnn);
}
// 应用加强 for 遍历 set 汇合
System.out.println("---------------");
for (Integer i : set) {System.out.println(i);
}
}
-----------------------------------------------------------------------------------------------------------------
1
2
3
---------------
1
2
3
最初
欢送关注公众号:前程有光,支付一线大厂 Java 面试题总结 + 各知识点学习思维导 + 一份 300 页 pdf 文档的 Java 外围知识点总结!这些材料的内容都是面试时面试官必问的知识点,篇章包含了很多知识点,其中包含了有基础知识、Java 汇合、JVM、多线程并发、spring 原理、微服务、Netty 与 RPC、Kafka、日记、设计模式、Java 算法、数据库、Zookeeper、分布式缓存、数据结构等等。