JUC随笔

什么是JUC

-java.util.concurrent
-java.util.concurrent.atomic
-java.util.concurrent.locks
业务:普通的线程代码 Thread
Runable 没有返回值、效率相比Callable较低

2.线程和进程

进程:一个程序
一个进程往往可以包含多个线程,至少包含一个
Java默认有两个线程:mian 和 GC
线程:开了进程Typora,鞋子,自动保存等
对于java而言:Thread、Runnable、Callable

并发和并行

并发编程:

  • 并发(多线程同时操作一个资源)
    -CPU,模拟出多条线程快速交替
  • 并行(多个线程一起走)
    并发编程的本质:充分利用CPU的资源

真正的多线程开发,公司中的开发,降低耦合性,线程就是一个单独的资源类,没有任何附属操作 属性、方法

传统锁synchronized:本质:队列、锁

lock锁

ReentranLock:可重入锁(常用)
ReentranReadWriteLock.ReadLock:读锁
ReentranReadWriteLock.WriteLock:写锁

公平锁:new FairSync()十分公平,可以先来后到
非公平锁:new NonFairSync()十分不公平,可以插队(默认)

lock锁和Synchronized的区别

1.Synchronized 内置java关键字,lock是一个java类
2.Synchronized 无法判断获取锁的状态,lock是可以判断是否获得锁
3.Synchronized 会自动释放锁,lock必须手动释放
4.Synchronized 线程1(获得锁、阻塞)线程二(等待),lock就不一定会等待下去
5.Synchronized 可重入锁,不可以中断的 ,非公平,lock,可重入锁可以判断锁,可以自己设置。
6.Synchronized 适应少量的代码同步,lock适合大量的代码

锁是什么,如何判断锁的是谁

8锁现象
对象、Class

Condition

创建方式:Condition condition = lock.newCondition();

Condition中的await()对应Object的wait();
Condition中的signal()对应Object的notify();
Condition中的signalAll()对应Object的notifyAll()。
可以实现对应锁的等待和开始

集合不安全

list、set
java.util.ConcurrentModficationException 并发修改异常
1.List<String> list = new Vector<>()
2.List<String> list = Collections.synchronizedList(new ArrayList<>())
3.List<String> list = new CopOnWriteArrayList<>()

CopOnWrite 写入时复制 COW 计算机程序设计领域的一种优化策略
写入时避免覆盖,造成数据问题
CopOnWrite 对比 Vector:vector用的是synchronized锁 而CopOnWrite用的是lock锁

Map
1.Map<String,String> map = Collections.synchronizedMap(new HashMap<>())
2.Map<String,String> map = new ConcurrentHashMap<>()

Callable对比Runnable

1.可以有返回值
2.可以抛出异常.
3.方法不同 run\call

new Thread(new FutureTask(Callable)).start()
有缓存、可能有阻塞

常用的辅助类

1.CountDownLatch

private void psvm() {
        // TODO 自动生成的方法存根
        // 总数是6
        CountDownLatch cdl = new CountDownLatch(6);
        
        for (int i = 0; i <= 6; i++) {
            new Thread(() -> {
                cdl.countDown();// -1
            }).start();
        }
        try {
            cdl.await();//等待计数器归零再向下执行
        } catch (InterruptedException e) {
            // TODO 自动生成的 catch 块
            e.printStackTrace();
        }
        System.err.println("关门");
    }

原理:
-countDown();// -1
-await();//等待计数器归零再向下执行
-每次有线程调用countDown()数量-1,当计数器为0,调用await()就会被唤醒继续执行

2.CyclicBarrier

加法计数器

 public static void main(String[] args) {
        CyclicBarrier cyclicBarrier = new CyclicBarrier(6,()->{
            System.out.println("数量达到6的时候调用");
        });
        for (int i = 1; i < 7; i++) {
            int a=i;
            new Thread(()->{
                try {
                    System.out.println(a);
                    cyclicBarrier.await();//+1
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } catch (BrokenBarrierException e) {
                    e.printStackTrace();
                }
            }).start();
        }

    }

1.当声明的屏障和线程调用的await次数相等时,先执行我们预声明的线程,
然后再执行调用await方法线程的后续代码.
2.重新调用count方法时,结果和第一次执行一样,说明CyclicBarrier的await方法是可以重复使用的.
3.CyclicBarrier就像团队中的领导,parties声明的屏障就是领导管理的员工数,线程就是员工,线程调用await方法就像是员工开会时报道,等全部员工报完道,
CyclicBarrier开始开会,会议开完后,然后员工再继续接着回去工作.

3.Semaphore

信号量

 public static void main(String[] args) {
        //线程数量
        Semaphore semaphore = new Semaphore(3);
        for (int i = 0; i < 6; i++) {
            new Thread(()->{
                try {
                    //acquire()得到
                    semaphore.acquire();
                    System.out.println(Thread.currentThread().getName()+"抢到车位");
                    TimeUnit.SECONDS.sleep(2);
                    System.out.println(Thread.currentThread().getName()+"离开车位");

                } catch (InterruptedException e) {
                    e.printStackTrace();
                }finally {
                    //.release()释放
                    semaphore.release();
                }
            },String.valueOf(i)).start();
        }


    }

作用:多个共享资源互斥的使用,并发限流,控制最大的线程数

读写锁 ReadWriteLock

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,817评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,329评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,354评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,498评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,600评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,829评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,979评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,722评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,189评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,519评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,654评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,329评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,940评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,762评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,993评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,382评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,543评论 2 349

推荐阅读更多精彩内容