Java内存模型(jmm)

  • Why:保证多线程正确协同工作

  • 看图说明:

    文字解释:线程a和线程b通信过程,首先线程a把本地内存的共享变量更新到主内存中,然后线程b去读取主内存的共享变量,最后更新到自己的本地内存中 ###JMM涉及的特性以及规则

  • 特性

    1.原子性:操作不可中断,即一个线程操作不会被另一个线程影响 特例:在32的操作系统中,long型不是原子性

    2.可见性:是指一个线程修改某个共享变量的值,另一个线程能否立刻知道该共享变量的变化。 经常出现可见问性问题是因为重排序 **重排序:**编译器和处理器为了提高执行效率,改变语句执行顺序,为此jmm有happenbefore规则。

    3.有序性: 代码语句按顺序执行

  • happenbefore规则

    happenbefore规则是jmm的核心:作用保证前一个操作对后一个操作可见(同一个线程或者不同线程)

    1.程序顺序原则:一个线程内保证语义的串行性

    2.Volatile规则:volatile的写,先发生于读,这保证了volatile的可见性

    3.锁规则:解锁必然发生在随后的加锁前

    4.传递性:a先于b,b先于c,那么a必然先于c

    5.线程的start()方法先于他的每一个动作

    6.线程所有操作先于线程的终结

    7.线程的中断先于被中断线程的代码

    8.对象的构造函数执行、结束先于finalize()方法

AQS同步器(抽象类)

  • 原理:使用int成员变量表示同步状态,通过内置fifo队列完成资源获取线程的排队工作

  • 他出名的儿子(继承了aqs)

    1.ReentrantLock(类):大家都叫他重入锁,因为他可以重复加锁,不过synchronized也有这功能。

    2.ReentrantReadWriteLock(类):大家都叫他读写锁,他可以听时刻允许多线程进入,读写锁比排它锁(ReentrantLock)性能好,因为大多数情况读多于写。

    3.CountDownLatch(类):大家叫他倒计时器,他允许一个或多个线程等待其他线程完成操作。

CyclicBarrier和CountDownLatch区别

  • CyclicBarrier

    1.同步屏障,用于多线程计算结果最后合并场景。

  • CountDownLatch

    1.CountDownLatch的计数器只能使用一次,cyclicbarrier的计数器可以重置

线程池(摆脱原始的线程创建方法)

  • 类图:如下

  • 使用:

    1.通过ThreadPoolExecutor创建线程池

  • 参数解释:

    1.int corePoolSize :线程池基本大小

    2.BlockingQueue :阻塞队列,用来保存等待执行的任务

    3.int maximumPoolSize:线程池最大数量,他与阻塞队列关系是这样4.审的,如果队列满了,线程池没有满,线程池会根据线程数量创执行任务。

    4.long keepAliveTime :空闲线程存或时间

    5.TimeUnit unit :线程活动保持时间的单位

  • 提交

    1.传递一个runnable(没有返回值),需要返回值使用submit()方法。

    threadPoolExecutor.execute(new Runnable() {@Overridepublic void run() {}
    });
    复制代码

转载于:https://juejin.im/post/5c2f8907f265da6169176102

Java线程入门第三篇相关推荐

  1. Java基础入门第三版黑马课后习题(编程部分)

    第 1 章 Java 开发入门 第 2 章 Java 编程基础 1. 编写程序,计算1+3+-+99的值,要求如下: (1)使用循环语句实现1~99的遍历 (2)在遍历过程中,通过条件判断当前的数是否 ...

  2. Avalonia跨平台入门第三篇之Popup

    前面已经分享了二篇关于Avalonia入门的文章,今天接着去摸索关于Popup的知识点;你还别说一上来就遇到坑了(后台定义的Popup直接黑框): 然而在WPF中没有出现这个Bug: 最后只能默默的再 ...

  3. sql基于聚合结果集取最大值_SQL超入门第三篇:写给产品、运营、分析师的SQL教程...

    序 前两节我们给大家讲解了如何查询数据及过滤查询.但在平时工作中,大家不止需要对数据进行检索,更需要的应该是对数据进行汇总计算,比如计算销售额,订单量,用户数,客单价,求首单时间等.本节我们就给大家讲 ...

  4. WPF入门第三篇 ControlTemplate、Trigger与Storyboard

    ControlTemplate.Trigger与Storyboard ControlTemplate通常用在Style中,Trigger通常作为ControlTemplate的一部分,StoryBoa ...

  5. 入门第三篇——坚持60秒

    题目描述:菜狗发现最近菜猫不爱理他,反而迷上了菜鸡 题目给的附件是一个jar包,如下图,运行后发现是一个游戏,题目的意思估计是让你玩这个有游戏,坚持60秒就能拿到flag. 游戏黑洞,坚持不了5秒就完 ...

  6. java邮件接收代码,JavaMail入门第四篇 接收邮件(示例代码)

    上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操 ...

  7. JavaMail入门第四篇 接收邮件

    上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操 ...

  8. java 读取邮件正文_JavaMail入门第五篇 解析邮件

    上一篇JavaMail入门第四篇 接收邮件中,控制台打印出的内容,我们无法阅读,其实,让我们自己来解析一封复杂的邮件是很不容易的,邮件里面格式.规范复杂得很.不过,我们所用的浏览器内置了解析各种数据类 ...

  9. Linux入门第三集!JDK8的Linux版本资源分享!jdk-8u301-linux-x64.rpm官方资源分享!Linux安装JDK8教程!

    Linux入门第三集!JDK8的Linux版本资源分享!jdk-8u301-linux-x64.rpm官方资源分享!Linux安装JDK8教程! 提取码均为0916 jdk-8u301-linux-x ...

最新文章

  1. java 操作txt文件
  2. 软件重构过程中的思维转换: 遗留代码如何变废为宝
  3. 用MFC制作程序启动logo
  4. Spring中类路径下文件读取方式
  5. javascript操作dom的一些函数
  6. python怎么执行程序_小鹅通视频怎么下载?用python实现小鹅通视频下载(二)
  7. ios 高德地图加载瓦片地图_IOS 高德地图 API 加载 WMS 服务
  8. Java是先难后易吗_在解决问题的时候,是先难后易还是先易后难?
  9. 七牛云注册创建oss并配置自定义域名
  10. Git Specification
  11. Poj(2679),SPFA,邻接表(主流写法)
  12. 游戏筑基开发之C语言回调函数使用实例及其.h库封装实例
  13. Json转换成excel 离线版
  14. 微信联盟链接不到服务器怎么,LOL微信登不上去怎么办?微信登不上解决方法推荐...
  15. linux如何运行rpm,LINUX下RPM的使用方法
  16. DSP TMS320C5509A 控制DDS AD9854芯片进行PSK相位调制
  17. Android 4.1 Netd详细分析(二)源文件/模块/基础类统领
  18. 主成分分析 (一): 基本思想与主成分估计方法
  19. KAPPA领衔实施服装ERP软件树立行业榜样
  20. VVIC api接口 Alex19970108016

热门文章

  1. 关于Office 365 域名绑定问题
  2. 重写了博客上的代码着色脚本
  3. myeclipse添加spket插件
  4. asp.net mvc 与 asp.net结合(asp.net mvc 技巧)
  5. 并发-9-Callable和Future
  6. 一篇文章带你了解https是如何做到客户端与服务端之间安全通信
  7. iKair:放弃硬件制造,切入上游去“送水”的逻辑
  8. unity meta文件
  9. 【MySQL】数据安全性讨论思维导图
  10. 问题 “No mapping found for HTTP request with URI [/fileupload/upload.do]” 的解决