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() {
@Override
public void run() { }
});

Java线程入门第三篇的更多相关文章

  1. JavaMail入门第三篇 发送邮件

    JavaMail API中定义了一个java.mail.Transport类,它专门用于执行邮件发送任务,这个类的实例对象封装了某种邮件发送协议的底层实施细节,应用程序调用这个类中的方法就可以把Mes ...

  2. Android JNI入门第三篇——jni头文件分析

    一. 首先写了java文件: public class HeaderFile { private native void  doVoid(); native int doShort(); native ...

  3. Html/Css(新手入门第三篇)

    一.学习心得---参考优秀的网页来学习. 1我们只做的静态网页主要用的技术?html+css 只要网上看到的,他的源代码公开的.[1].先去分析,他们页面是如何布局(结构化)[2].再试着去做一下,- ...

  4. Hadoop入门第三篇-MapReduce试手以及MR工作机制

    MapReduce几个小应用 上篇文章已经介绍了怎么去写一个简单的MR并且将其跑起来,学习一个东西动手还是很有必要的,接下来我们就举几个小demo来体验一下跑起来的快感. demo链接请参照附件:ht ...

  5. Visualforce入门第三篇_2017.3.2

    Visualforce实现显示Record List(列表) 详细见链接:https://trailhead.salesforce.com/modules/visualforce_fundamenta ...

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

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

  7. JavaMail入门第五篇 解析邮件

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

  8. jQuery入门第三

    jQuery入门第三 1.HTML 2.CSS 衣服 3.javascript 可以动的人 4.DOM 编程 对html文档的节点操作 5.jQuery 对 javascript的封装 简练的语法 复 ...

  9. Windbg 进程与线程 《第三篇》

    Windbg既可以显示进程和线程列表,又可以显示指定进程或线程的详细信息.调试命令可以提供比taskmgr更详尽的进程资料,在调试过程中不可或缺. 一.进程命令 进程命令包括这些内容:显示进程列表.进 ...

随机推荐

  1. 910. Smallest Range II

    Given an array A of integers, for each integer A[i] we need to choose either x = -K or x = K, and ad ...

  2. “全栈2019”Java第十八章:一元运算符

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  3. dos 下脚本编写须知

    主题为:doc脚本运行结束后,不自动退出终端. 方法1假设你的bat名字叫rabbit.bat你可以新开一个bat,内容是start rabbit.bat然后这个新的bat是不会自动关闭的 注意,这个 ...

  4. CentOS7 安装 Docker CE步骤

    准备工作 系统要求 Docker CE 支持 64 位版本 CentOS 7,并且要求内核版本不低于 3.10. CentOS 7 满足最低内核的要求,但由于内核版本比较低,部分功能(如 overla ...

  5. CSS 加号选择器("+")

    加号选择器("+"):就是指对找到的某类的元素除第一个元素以外的兄弟元素起作用,即第一个元素不起作用,后面的兄弟元素都会起作用   效果:给每一个li加一个border-left, ...

  6. MUI 滚动插件使用

    在Vue中 使用MUI滚动插件 官方文档地址:http://dev.dcloud.net.cn/mui/ui/#scroll 示例:初始化scroll控件: mui('.mui-scroll-wrap ...

  7. 3期浅析宽字节注入-----SQL注入

    通过分类的名称,你就可以找到漏洞银行的hack show视频. 吸收这个知识的几个关键的信息. 1.通过视频得到知识源.         [信息来源] 我怎么从不清楚到知道这个信息来源?这个过程没办法 ...

  8. HDU4622 (查询一段字符串的不同子串个数,后缀自动机)

    http://acm.hdu.edu.cn/showproblem.php?pid=4622 题意:给出一个字符串和q次询问,每次询问[l,r]区间内不同子串的个数 分析: N<=2000. 我 ...

  9. [转] Ansible 进阶 | facts 缓存

    [From] https://blog.csdn.net/bruce_6/article/details/81328975 什么是 Ansible factsAnsible facts 是远程系统的信 ...

  10. Ubuntu定时任务设置

    设置很简单,但如果误入歧途,会耽误很多时间 步骤如下: 1. 以root执行:vi /etc/crontab 2. 在文件最后添加cron配置(每天凌晨四点执行,并将日志输出到/data/cron.l ...