随笔分类 -  JUC

java 多线程知识学习
Java并发编程原理与实战四十五:问题定位总结
摘要:背景 “线下没问题的”、 “代码不可能有问题 是系统原因”、“能在线上远程debug么” 线上问题不同于开发期间的bug,与运行时环境、压力、并发情况、具体的业务相关。对于线上的问题利用线上环境可用的工具,收集必要信息 对定位问题十分重要。 对于导致问题的bug、资源瓶颈很难直观取得数据,需要根据资 阅读全文

posted @ 2018-08-31 19:23 pony1223 阅读(411) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战四十四:final域的内存语义
摘要:一.final域的重排序规则 对于final域,编译器和处理器要遵循两个重拍序规则: 1.在构造函数内对一个final域的写入,与随后把这个被构造对象的引用赋值给一个引用变量,这两个操作之间不能重排序。 2.初次读一个包含final域的对象的应用,与随后初次读这个final域,这两个操作之间不能重排 阅读全文

posted @ 2018-08-31 19:04 pony1223 阅读(300) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战四十三:CAS ---- ABA问题
摘要:CAS(Compare And Swap)导致的ABA问题 问题描述 多线程情况下,每个线程使用CAS操作欲将数据A修改成B,当然我们只希望只有一个线程能够正确的修改数据,并且只修改一次。当并发的时候,其中一个线程已经将A成功的改成了B,但是在线程并发调度过程中尚未被调度,在这个期间,另外一个线程( 阅读全文

posted @ 2018-08-31 18:59 pony1223 阅读(303) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战四十二:锁与volatile的内存语义
摘要:锁与volatile的内存语义 1.锁的内存语义 2.volatile内存语义 3.synchronized内存语义 4.Lock与synchronized的区别 5.ReentrantLock源码实例分析 1.锁的内存语义 锁是java并发编程中最重要的同步机制。锁除了让临界区互斥执行外,还可以让 阅读全文

posted @ 2018-08-31 18:52 pony1223 阅读(338) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战四十一:重排序 和 happens-before
摘要:一、概念理解 首先我们先来了解一下什么是重排序:重排序是指编译器和处理器为了优化程序性能而对指令序列进行重新排序的一种手段。 从Java源代码到最终实际执行的指令序列,会分别经历下面3种重排序,如下图所示 上述的1属于编译器重排序,2和3属于处理器重排序。这些重排序可能会导致多线程程序出现内存可见性 阅读全文

posted @ 2018-08-31 18:43 pony1223 阅读(421) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战四十:JDK8新增LongAdder详解
摘要:传统的原子锁AtomicLong/AtomicInt虽然也可以处理大量并发情况下的计数器,但是由于使用了自旋等待,当存在大量竞争时,会存在大量自旋等待,而导致CPU浪费,而有效计算很少,降低了计算效率。 而LongAdder是根据ConcurrentHashMap这类为并发设计的类的基本原理——锁分 阅读全文

posted @ 2018-08-29 08:18 pony1223 阅读(905) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十九:JDK8新增锁StampedLock详解
摘要:1、StampedLock是做什么的? 》它是ReentrantReadWriteLock 的增强版,是为了解决ReentrantReadWriteLock的一些不足。 2、ReentrantReadWriteLock有什么不足之处呢? 》我们都知道,ReentrantReadWriteLock是读 阅读全文

posted @ 2018-08-29 08:12 pony1223 阅读(878) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十八:多线程调度器(ScheduledThreadPoolExecutor)
摘要:在前面介绍了java的多线程的基本原理信息:线程池的原理与使用 本文对这个java本身的线程池的调度器做一个简单扩展,如果还没读过上一篇文章,建议读一下,因为这是调度器的核心组件部分。 我们如果要用java默认的线程池来做调度器,一种选择就是Timer和TimerTask的结合:一个Timer为一个 阅读全文

posted @ 2018-08-24 08:15 pony1223 阅读(829) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十七:线程池的原理与使用
摘要:一、简介 线程池在我们的高并发环境下,实际应用是非常多的!!适用频率非常高! 有过使用过Executors框架的朋友,可能不太知道底层的实现,这里就是讲Executors是由ThreadPoolExecutor实现的。好的,让我们来看看ThreadPollExcutor是怎样实现的呢? 如果你想了解 阅读全文

posted @ 2018-08-24 08:14 pony1223 阅读(591) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十六:阻塞队列&消息队列
摘要:一、阻塞队列 1、阻塞队列BlockingQueue 》可以理解成生产者消费者的模式 》消费者要等待到生产者生产出来产品。 》而非阻塞队列ConcurrentLinkedQueue是非阻塞的,所以它取出来的时候可能为空。 2、注意使用BlockingQueue接口的时候。 add方法和remove方 阅读全文

posted @ 2018-08-23 08:14 pony1223 阅读(5835) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十五:并发容器ConcurrentLinkedQueue原理与使用
摘要:一、简介 offer和poll offer(E e) 将指定元素插入此队列的尾部。 poll() 获取并移除此队列的头,如果此队列为空,则返回 null。 offer是往队列添加元素,poll是从队列取出元素并且删除该元素 执行结果 ConcurrentLinkedQueue中的add() 和 of 阅读全文

posted @ 2018-08-21 08:16 pony1223 阅读(6521) 评论(1) 推荐(1) 编辑

Java并发编程原理与实战三十四:并发容器CopyOnWriteArrayList原理与使用
摘要:1、ArrayList的实现原理是怎样的呢? 》例如:ArrayList本质是实现了一个可变长度的数组。 假如这个数组的长度为10,调用add方法的时候,下标会移动到下一位,当移动到70%左右的时候。会创建一个新数组,而这个新数组的长度变成2倍或3倍等等。将原来的数据复制到新数组中,新的内容会接着添 阅读全文

posted @ 2018-08-20 08:30 pony1223 阅读(470) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十三:同步容器与并发容器
摘要:1、什么叫容器? 》数组,对象,集合等等都是容器。 2、什么叫同步容器? 》Vector,ArrayList,HashMap等等。 3、在多线程环境下,为什么不用同步容器呢? 》1、线程不安全问题。2、线程安全的情况下,但是性能非常差问题。 Vector(线程安全,基本不用) 》ArrayList( 阅读全文

posted @ 2018-08-19 21:39 pony1223 阅读(217) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十二:ForkJoin框架详解
摘要:1、Fork/Join框架有什么用呢? 》Fork使用来切分任务,Join是用来汇总结果。举个简单的栗子:任务是1+2+3+...+100这个任务(当然这个任务的结果有好的算法去做,现在是用笨方法去计算这个结果)。 》适合在多核环境下,单核环境使用ForkJoin没什么意思。简单来说就是,一个任务切 阅读全文

posted @ 2018-08-19 21:37 pony1223 阅读(485) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战三十一:Future&FutureTask 浅析
摘要:一、Futrue模式有什么用? >正所谓技术来源与生活,这里举个栗子。在家里,我们都有煮菜的经验。(如果没有的话,你们还怎样来泡女朋友呢?你懂得)。现在女票要你煮四菜一汤,这汤是鸡汤,有常识的人鸡汤要煲好久滴。如果你先炒四个菜,最后再煲汤,估计都已经一天的时间了。好了。如果我们先煲汤,在煲汤的时候, 阅读全文

posted @ 2018-08-19 21:33 pony1223 阅读(954) 评论(2) 推荐(2) 编辑

Java并发编程原理与实战三十:CountDownLatch与CyclicBarrier 区别
摘要:相信每个想深入了解多线程开发的Java开发者都会遇到CountDownLatch和CyclicBarrier,大家也在网上看到各种介绍原理,代码的,以及他们区别(应付面试)的,但是很少能讲清楚:他们到底有啥作用,怎么用,应用那些场景?为什么面试总会遇到?本文结合场景为大家加深理解。 理解: Coun 阅读全文

posted @ 2018-08-16 08:28 pony1223 阅读(237) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战二十九:Exchanger
摘要:一、简介 前面三篇博客分别介绍了CyclicBarrier、CountDownLatch、Semaphore,现在介绍并发工具类中的最后一个Exchange。Exchange是最简单的也是最复杂的,简单在于API非常简单,就一个构造方法和两个exchange()方法,最复杂在于它的实现是最复杂的。在 阅读全文

posted @ 2018-08-16 08:22 pony1223 阅读(750) 评论(0) 推荐(1) 编辑

Java并发编程原理与实战二十八:信号量Semaphore
摘要:1.Semaphore简介 Semaphore,是JDK1.5的java.util.concurrent并发包中提供的一个并发工具类。 所谓Semaphore即 信号量 的意思。 这个叫法并不能很好地表示它的作用,更形象的说法应该是许可证管理器。 其作用在JDK注释中是这样描述的: A counti 阅读全文

posted @ 2018-08-15 08:30 pony1223 阅读(6237) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战二十七:循环栅栏:CyclicBarrier
摘要:昨天我们学习了倒计数功能的等待,今天我们学习的是循环栅栏:CyclicBarrier。下面我们就开始吧: 1.CyclicBarrier简介CyclicBarrier,是JDK1.5的java.util.concurrent并发包中提供的一个并发工具类。所谓Cyclic即 循环 的意思,所谓Barr 阅读全文

posted @ 2018-08-15 08:24 pony1223 阅读(1332) 评论(0) 推荐(0) 编辑

Java并发编程原理与实战二十六:闭锁 CountDownLatch
摘要:关于闭锁 CountDownLatch 之前在网上看到过一篇举例非常形象的例子,但不记得是出自哪里了,所以这里就当自己再重新写一篇吧: 例子如下: 我们每天起早贪黑的上班,父母每天也要上班,有一天定了一个饭店,一家人一起吃个饭,通知大家下班去饭店集合。 假设:3个人在不同的地方上班,必须等到3个人到 阅读全文

posted @ 2018-08-14 08:19 pony1223 阅读(563) 评论(0) 推荐(1) 编辑

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示