- 博客(6)
- 收藏
- 关注
原创 并发编程14
并发编程14 定义一个线程池 package BingFaBianCheng.bingFaBianCheng14.poolv1; import lombok.extern.slf4j.Slf4j; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; /** * @Author 钢牌讲师--子路 **/ @Slf4j(topic = "e") public class TestPo
2020-12-18 02:47:07 123
原创 并发编程13
并发编程13 高性能读写锁StampedLock(jdk内部的) ReentrantReadWriteLock 的性能已经很好了但是他底层还是需要进行一系列的cas操作去加锁; StampedLock如果是读锁上锁是没有这种cas操作的性能比ReentrantReadWriteLock 更好 也称为乐观读锁;即读获取锁的时候 是不加锁 直接返回一个值;然后执行临界区的时候去验证这个值是否有被人修改(写操作加锁) 如果没有被人修改则直接执行临界区的代码;如果被人修改了则需要升级为读写锁 (Reentrant
2020-12-17 02:13:39 197
原创 并发编程12
并发编程12–ReentrantLock解锁流程和读写锁源码 {w thread=t1} ^ | V {r thread=t2 ws=-1} <-> {shared thread=null prev=null next=null} // 比普通独占锁中的节点多了shared属性,下一个节点是shared继续唤醒,直到遇到exclusive ^ | V {r thread=t3 ws=-1} <-> {share
2020-12-15 01:04:13 147
原创 并发编程11
并发编程11 t1释放锁之后,唤醒t2线程,t2线程从LockSupport.park()处唤醒,继续往下执行 Thread.interrupted()并不是打断线程,只是清除打断标记 线程打断 sleep、wait、join这种线程如果被打断则会直接清除打断标记 --> 什么是打断标记 1.怎么看打断标记? Thread.interrupted() 2.打断标记是标记自己这个线程是否被别人打断过了 例子1—sleep线程打断 package BingFaBianCheng.bin
2020-12-12 02:08:41 185 1
原创 并发编程10
并发编程10 读写锁 读读并发 package BingFaBianCheng.DuXieSuo; import lombok.extern.slf4j.Slf4j; import java.util.concurrent.TimeUnit; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantReadWriteLock; @Slf4j(topic = "enjoy") publi
2020-12-11 00:13:27 255
原创 leetcode
参考地址 https://github.com/yuanguangxin/LeetCode https://blog.csdn.net/lingpy/article/details/88085446 https://blog.csdn.net/CowBoySoBusy/article/details/82559651
2020-12-08 01:41:55 119
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人