使用并发集视图的可能考虑是:你可能不想要一个大的线程安全的映射,而是想用一个集。
<br/>
可以调用下面的几个方法创建不同特性的集。
<br/>
**1. newKeySet**
对 Set 的任何更改,均不影响 ConcurrentHashMap。
```java
@Test
public void newKeySetTest() {
Set<String> words = ConcurrentHashMap.<String>newKeySet();
words.add("张三");
words.add("李四");
for (String word : words) {
System.out.println(word);
}
}
```
**2.`keySet()`**
keySet(),其实就是 ConcurrentHashMap 中 key 集合。
由该方法得到的Set只能删除元素,不能添加元素。在Set中删除了键,则ConcurrentHashMap 中的键/值一同被删除。
```java
@Test
public void keySetTest1() {
ConcurrentHashMap<String, String> map = new ConcurrentHashMap<>(1);
map.put("1", "张三");
map.put("2", "李四");
map.forEach((k, v) -> System.out.println("k: " + k + ", v: " + v));
//k: 1, v: 张三
//k: 2, v: 李四
Set<String> set = map.keySet();
//set.add("王五"); 不支持添加,否则运行时抛出异常。
set.remove("1");
set.forEach(k -> System.out.println(k));
//2
map.forEach((k, v) -> System.out.println("k: " + k + ", v: " + v));
//k: 2, v: 李四
}
```
**3. `keySet(V mappedValue)`**
该方法可以添加,删除元素,在Set中添加 ,或删除了键,则 ConcurrentHashMap 中的键/值一同被增加,或删除。
```java
@Test
public void keySetTest2() {
ConcurrentHashMap<String, String> map = new ConcurrentHashMap<>(1);
map.put("1", "张三");
map.put("2", "李四");
map.forEach((k, v) -> System.out.println("k: " + k + ", v: " + v));
//k: 1, v: 张三
//k: 2, v: 李四
Set<String> set = map.keySet("王五");
set.add("3");
set.forEach(k -> System.out.println(k));
//1
//2
//3
map.forEach((k, v) -> System.out.println("k: " + k + ", v: " + v));
//k: 1, v: 张三
//k: 2, v: 李四
//k: 3, v: 王五
set.remove("1");
set.forEach(k -> System.out.println(k));
//2
//3
map.forEach((k, v) -> System.out.println("k: " + k + ", v: " + v));
//k: 2, v: 李四
//k: 3, v: 王五
}
```
- 网络通信
- 网络协议
- 端口和套接字
- TCP网络程序
- UDP网络程序
- 多线程聊天室
- 多线程
- 线程相关概念
- 线程实现方式
- 中断线程
- 线程生命周期
- 线程优先级
- 优先级规则
- 案例演示
- 线程同步机制
- 线程同步机制
- synchronized关键字
- ReentrantLock类
- Condition类
- 监视器概念
- volatile关键字
- final变量
- 死锁
- 线程局部变量
- 读/写锁
- 原子类
- 阻塞队列
- 工作规则
- 案例演示
- 常用阻塞队列
- 线程安全集合
- 高效的映射/集/队列
- 并发集视图
- 写数组的拷贝
- Arrays类的并行数组算法
- 同步包装器
- Callable与Future
- 执行器
- 线程池
- 预定执行
- 控制任务组
- Fork-Join框架
- 同步器
- 同步器
- 信号量
- CountDownLatch类
- CyclicBarrier类
- Exchanger类
- SynchronousQueue类
- 线程与Swing
- Swing与线程问题
- 两个原则
- Swing工作线程
- 单一线程规则
- 文件IO
- File类
- 文件输入输出
- ZIP压缩文件
- 集合
- 集合框架
- 集合接口
- 集合实现类
- 线程安全集合
- 集合算法
- 迭代器
- 集合排序
- JDBC
- JDBC是什么
- JDBC-ODBC桥
- JDBC驱动程序类型
- JDBC常用类与接口
- 数据库操作
- 连接数据库
- 增/删/改/查/预处理
- 事务
- 批处理
- commons-dbutils工具
- 安全问题
- Jedis
- 使用Jedis操作Redis数据库
- JSON转换
- 使用连接池
- 案例
- 单例破坏
- 单例定义
- 单例实现方式
- 懒汉式实现单例
- 饿汉式实现单例
- 单例破坏
- 类的单例破坏
- 枚举的单例破坏
- 克隆
- 克隆是什么
- 浅克隆
- 深克隆
- 注解
- 注解是什么
- 三大注解
- 内置注解
- 元注解
- 自定义注解
- NIO
- 相关概念
- BIO/NIO/AIO
- 多线程编程
- 线程同步
- 线程通信
- NIO
- NIO三大核心组件
- NIO网络编程
- NIO文件读写
- AIO
- Java8新特性
- Lambda表达式
- 方法引用
- 函数式接口
- 默认方法
- 什么是默认方法
- 默认方法语法格式
- 多个同名的默认方法问题
- 静态默认方法
- 默认方法实例
- Stream
- Stream是什么
- Stream示例
- Optional容器
- 新的日期时间API
- Base64
- SPI
- SPI是什么
- SPI与API的区别
- 常见场景
- 使用SPI需遵循的约定
- SPI使用步骤