Java线程入门第三篇
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线程入门第三篇的更多相关文章
- JavaMail入门第三篇 发送邮件
JavaMail API中定义了一个java.mail.Transport类,它专门用于执行邮件发送任务,这个类的实例对象封装了某种邮件发送协议的底层实施细节,应用程序调用这个类中的方法就可以把Mes ...
- Android JNI入门第三篇——jni头文件分析
一. 首先写了java文件: public class HeaderFile { private native void doVoid(); native int doShort(); native ...
- Html/Css(新手入门第三篇)
一.学习心得---参考优秀的网页来学习. 1我们只做的静态网页主要用的技术?html+css 只要网上看到的,他的源代码公开的.[1].先去分析,他们页面是如何布局(结构化)[2].再试着去做一下,- ...
- Hadoop入门第三篇-MapReduce试手以及MR工作机制
MapReduce几个小应用 上篇文章已经介绍了怎么去写一个简单的MR并且将其跑起来,学习一个东西动手还是很有必要的,接下来我们就举几个小demo来体验一下跑起来的快感. demo链接请参照附件:ht ...
- Visualforce入门第三篇_2017.3.2
Visualforce实现显示Record List(列表) 详细见链接:https://trailhead.salesforce.com/modules/visualforce_fundamenta ...
- JavaMail入门第四篇 接收邮件
上一篇JavaMail入门第三篇 发送邮件中,我们学会了如何用JavaMail API提供的Transport类发送邮件,同样,JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操 ...
- JavaMail入门第五篇 解析邮件
上一篇JavaMail入门第四篇 接收邮件中,控制台打印出的内容,我们无法阅读,其实,让我们自己来解析一封复杂的邮件是很不容易的,邮件里面格式.规范复杂得很.不过,我们所用的浏览器内置了解析各种数据类 ...
- jQuery入门第三
jQuery入门第三 1.HTML 2.CSS 衣服 3.javascript 可以动的人 4.DOM 编程 对html文档的节点操作 5.jQuery 对 javascript的封装 简练的语法 复 ...
- Windbg 进程与线程 《第三篇》
Windbg既可以显示进程和线程列表,又可以显示指定进程或线程的详细信息.调试命令可以提供比taskmgr更详尽的进程资料,在调试过程中不可或缺. 一.进程命令 进程命令包括这些内容:显示进程列表.进 ...
随机推荐
- Spring boot整合Mongodb
最近的项目用了Mongodb,网上的用法大多都是七零八落的没有一个统一性,自己大概整理了下,项目中的相关配置就不叙述了,由于spring boot的快捷开发方式,所以spring boot项目中要使用 ...
- “全栈2019”Java第五十三章:向上转型和向下转型详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
- 【maven】---聚合和继承
前言 自从我知道写maven实战这本书的作者长得随心所欲后,我再拿起这本书真心的不想看前言了.下面分享一下maven中的所谓的聚合和继承. 内容 下文中的子本指的是:多个maven项目. 父本指的是: ...
- Ping程序
一.概述 Ping程序是对两个TCP/IP系统连通性进行测试的基本工具.该程序发送一份ICMP回显请求报文给主机,并等待返回ICMP回显应答. 二.格式 大多数TCP/IP实现都在内核中直接支持Pin ...
- Python3之 contextlib
Python中当我们们打开文本时,通常会是用with语句,with语句允许我们非常方便的使用资源,而不必担心资源没有关闭. with open('/path/filename', 'r') as f: ...
- 05. flex元素水平垂直居中(三种position水平垂直居中和两种新老版本水平垂直居中)
flex元素水平垂直居中(三种position水平垂直居中和两种新老版本水平垂直居中) (1).position : <!DOCTYPE html> <html lang=" ...
- 持续集成、持续交付、持续部署、Jkens、git
一 持续集成.持续交付.持续部署 1. 持续集成 持续集成指的是,频繁地(一天多次)将代码集成到主干.持续集成的目的,就是让产品可以快速迭代,同时还能 保持高质量.它的核心措施是,代码集成到主干之前 ...
- localStorage、sessionStorage用法总结
1.作用 1.1 共同点: 都是用来存储客户端临时信息的对象. 均只能存储字符串类型的对象(虽然规范中可以存储其他原生类型的对象,但是目前为止没有浏览器对其进行实现). 1.2 ...
- SQL语句exists用法
首先头脑中有三点概念: 1 . EXISTS子查询找到的提交 NOT EXISTS 子查询中 找不到的提交 说明:不要去翻译为存在和不存在,把脑袋搞晕. 2 . 建立程序循环的概念,这是一个动态的查 ...
- es第三篇:Search APIs
大多数search API都是可以操作多个索引的,除了explain API. 当执行一个search API时,可以指定routing参数,去搜索特定的主分片及其副本分片.routing参数值可以是 ...