摘要:
IO 服务端ServerSocket 客户端Socket 缺点每次客户端建立连接都会另外启一个线程处理。读取和发送数据都是阻塞式的。 如果1000个客户端建立连接将会产生1000个线程 测试类 输出 Nio nio改善了io一个客户端建立连接就创建一个线程监听请求的模型。 nio的核心概念 1.Ch 阅读全文
摘要:
ReentrantLock源码 https://www.cnblogs.com/LQBlog/p/15206866.html 简单demo 在多线程操作时。保证一块共享资源的原子性。第一想到的就是用synchronized关键字 在jdk5提供一个更灵活更强大的 ReentrantLock 使用re 阅读全文
摘要:
限制并发资源的并发访问数量。 samephore.acquire(); 获取许可 samephore.release(); 释放一个许可。 模拟银行10个办理任务的窗口。 samephore.acquire() 如果有10个任务获取许可并没有释放 其他人等待 某一个获取许可正在执行的任务 释放许可才 阅读全文
摘要:
应用场景 财务成本核算。可能会有多个耗时的步骤。如果顺序执行是非常慢的。再相互数据获取数据不依赖的情况下可以使用Future并行执行 自己实现future异步加载 调用getData 方法如果没有setData 则state是false 则释放锁 加入到等待队列 当你get方法线程加载完数据再set 阅读全文
摘要:
CountDownLatch CountDownLatch是jdk5 java.util.concurrent新增的的工具类 使用场景。如:导出excel需要解析创建多个sheel。创建多线程并行执行。执行完毕 相应给客户端 public static void main(String[] args 阅读全文
摘要:
线程池的好处 降低资源消耗。虽然我们程序员创建一个线程很容易,直接使用 new Thread() 创建就可以了,但是操作系统做的工作会多很多,它需要发出 系统调用,陷入内核,调用内核 API 创建线程,为线程分配资源等,这一些操作有很大的开销,通过重复利用已创建的线程降低线程创建和销毁造成的消耗。 阅读全文
摘要:
非阻塞无界队列 ConcurrentLinkedQueue public static void main(String[] args) throws InterruptedException { ConcurrentLinkedQueue queue=new ConcurrentLinkedQue 阅读全文
摘要:
ArrayList在单线程下是高效的,但是在多线程下是线程不安全的 ArrayList在多线程的线程不安全的几种体现 删除元素时。a和b同时删除索引为4个数据。这个时候a线程先执行 将4后面的元素往前移动一位。size-- 这个时候b线程也删除 就删除到别的元素。如果是删除第一个元素。a线程size 阅读全文
摘要:
HashMap不是线程安全的。在多线程操作下 可能会数据丢失! 首先我们了解一下hashmap的存储结构。 hashmap内部是通过数组加链表的形式存储的。 链表的作用则是防止hash碰撞产生的数据丢失而设计的。 什么是hash碰撞 2个不同的key hashcode相同 比如key1通过hashc 阅读全文
摘要:
volatile关键字的2个作用 1.线程的可见性 2.防止指令重排 什么是线程的可见性? 线程的可见性 就是一个线程对一个变量进行更改操作 其他线程获取会获得最新的值。 线程在执行的行 操作主线程的变量。会将变量的副本拷贝一份到线程的工作区域(避免每次到主线程读取 提高效率),在更改后的一段时间内 阅读全文