Single Threaded Execution模式

以下是学习了《图解Java多线程设计模式》一书中记录的内容

Single Threaded Execution模式——能通过这座桥的只有一个人

Single Threaded Execution模式是多线程设计的基础。

Single Threaded Execution即“以一个线程执行”。就像独木桥同一时间只允许一个人通行一样。

Single Threaded Execution有时候也称为临界区(critical section)或临界域(critical region)。Single Threaded Execution这个名称侧重于执行处理的线程(过桥的人),而临界区或临界域的名称侧重于执行范围(人过的桥)。

该模式操作的角色就是SharedResource(共享资源),该类具有两种类型的方法:

  1. safeMethod:多个线程同时调用也不会发生问题的方法。
  2. unsafeMethod:多个线程同时调用会发生问题,因此必须加以保护的方法。
要点
何时使用

1、多线程时:但线程程序不需要使用该模式,即无需使用synchronized,当然单线程使用synchronized也不会破坏安全性,但是性能会有所下降;

2、多个线程访问时:Share Resource角色的实例有可能被多个线程同时访问时;

3、状态有可能发生变化时:Share Resource角色的状态会发生变化,当然,如果实例创建后,实例的状态不会发生改变,例如Immutable模式中,则无需使用Single Threaded Execution模式;

4、需要确保安全性时:当然,只有在需要确保安全性时,才需要使用Single Threaded Execution模式;

tips:Java提供了针对集合类的线程安全方法如下

Collections.synchronizedCollection();
Collections.synchronizedList();
Collections.synchronizedMap();
Collections.synchronizedSet();
Collections.synchronizedSortedMap();
Collections.synchronizedSortedSet();
生存性与死锁

使用Single Threaded Execution会存在发生死锁的风险,发生死锁需要满足如下几个条件:

(1)存在多个ShareResource角色;

(2)线程在持有某个ShareResource角色的锁的同时,还想获取其他ShareResource角色的锁;

(3)获取ShareResource角色的锁的顺序并不固定(ShareResource角色是对称的);

如何防止死锁发生:只要破坏(1)、(2)、(3)中的一个条件即可。

可复用性和继承反常

假设要编写一个ShareResource的子类,如果子类能够访问ShareResource角色的字段,那么就有可能子类会出现unsafeMethod,即便能避免,那么在更多子类化的情况下还是会出现ShareResource的安全性问题。

在面向对象的程序设计中,伴随着子类话而出现的“继承”起着非常重要的作用。但对于多线程程序设计来说,继承会引起一些麻烦的问题,通常称之为继承反常(inheritance anomaly)。

临界区的大小和性能

Single Threaded Execution模式会降低程序性能,原因有两个方面:

1、获取锁花费时间:进入synchronized方法或者代码块时,线程获取对象锁花费时间

2、线程冲突引起的等待:当某一个线程执行临界区处理时,其他想要进入临界区的线程会阻塞。这种情况称之为线程冲突(conflict)。发生冲突时,程序的整体性能会随着线程等待时间的增加而下降。如果尽可能地缩小临界区的范围,降低线程冲突的概率,那么就能够抑制性能的下降。

tips:这里可以对比ConcurrentHashMap和Hashtable的底层实现,Hashtable所有方法都采用了Single Threaded Execution模式,而ConcurrentHashMap底层是基于分段锁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
[JAVA工程师必会知识点之并发编程]1、现在几乎100%的公司面试都必须面试并发编程,尤其是互联网公司,对于并发编程的要求更高,并发编程能力已经成为职场敲门砖。2、现在已经是移动互联和大数据时代,对于应用程序的性能、处理能力、处理时效性要求更高了,传统的串行化编程无法充分利用现有的服务器性能。3、并发编程是几乎所有框架的底层基础,掌握好并发编程更有利于我们学习各种框架。想要让自己的程序执行、接口响应、批处理效率更高,必须使用并发编程。4、并发编程是中高级程序员的标配,是拿高薪的必备条件。 【主讲讲师】尹洪亮Kevin:现任职某互联网公司首席架构师,负责系统架构、项目群管理、产品研发工作。10余年软件行业经验,具有数百个线上项目实战经验。擅长JAVA技术栈、高并发高可用伸缩式微服务架构、DevOps。主导研发的蜂巢微服务架构已经成功支撑数百个微服务稳定运行【推荐你学习这门课的理由:知识体系完整+丰富学习资料】1、 本课程总计122课时,由五大体系组成,目的是让你一次性搞定并发编程。分别是并发编程基础、进阶、精通篇、Disruptor高并发框架、RateLimiter高并发访问限流吗,BAT员工也在学。2、课程附带附带3个项目源码,几百个课程示例,5个高清PDF课件。3、本课程0基础入门,从进程、线程、JVM开始讲起,每一个章节只专注于一个知识点,每个章节均有代码实例。 【课程分为基础篇、进阶篇、高级篇】一、基础篇基础篇从进程与线程、内存、CPU时间片轮训讲起,包含线程的3种创建方法、可视化观察线程、join、sleep、yield、interrupt,Synchronized、重入锁、对象锁、类锁、wait、notify、线程上下文切换、守护线程、阻塞式安全队列等内容。二、进阶篇进阶篇课程涵盖volatied关键字、Actomic类、可见性、原子性、ThreadLocal、Unsafe底层、同步类容器、并发类容器、5种并发队列、COW容器、InheritableThreadLocal源码解析等内容。三、精通篇精通篇课程涵盖JUC下的核心工具类,CountDownLath、CyclicBarrier、Phaser、Semaphore、Exchanger、ReentrantLock、ReentrantReadWriteLock、StampedLock、LockSupport、AQS底层、悲观锁、乐观锁、自旋锁、公平锁、非公平锁、排它锁、共享锁、重入锁、线程池、CachedThreadPool、FixedThreadPool、ScheduledThreadPool、SingleThreadExecutor、自定义线程池、ThreadFactory、线程池切面编程、线程池动态管理等内容,高并发设计模式,Future模式、Master Worker模式、CompletionService、ForkJoin等课程中还包含Disruptor高并发无锁框架讲解:Disruptor支持每秒600万订单处理的恐怖能力。深入到底层原理和开发模式,让你又懂又会用。高并发访问限流讲解:涵盖木桶算法、令牌桶算法、Google RateLimiter限流开发、Apache JMeter压力测试实战。 【学完后我将达到什么水平?】1、 吊打一切并发编程相关的笔试题、面试题。2、 重构自己并发编程的体系知识,不再谈并发色变。3、 精准掌握JAVA各种并发工具类、方法、关键字的原理和使用。4、 轻松上手写出更高效、更优雅的并发程序,在工作中能够提出更多的解决方案。  【面向人群】1、 总感觉并发编程很难、很复杂、不敢学习的人群。2、 准备跳槽、找工作、拿高薪的程序员。3、 希望提高自己的编程能力,开发出更高效、性能更强劲系统的人群。4、 想要快速、系统化、精准掌握并发编程的人群。【课程知识体系图】

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值