多线程在面试中基本上已经是必问项了,面试官通常会从简单的问题开始发问,然后再一步一步的挖掘你的知识面。
比如,从线程是什么开始,线程和进程的区别,创建线程有几种方式,线程有几种状态,等等。
接下来自然就会引出线程池,Lock,Synchronized,JUC的各种并发包。然后就会引出 AQS、CAS、JMM、JVM等偏底层原理,一环扣一环。
这一节我们不聊其他的,只说创建线程有几种方式。
是不是感觉非常简单,不就是那个啥啥那几种么。
其实不然,只有我们给面试官解释清楚了,并加上我们自己的理解,才能在面试中加分。
分类:
编程语言 时间:
2020-10-31 01:27:12
阅读次数:
74
多线程在面试中基本上已经是必问项了,面试官通常会从简单的问题开始发问,然后再一步一步的挖掘你的知识面。
比如,从线程是什么开始,线程和进程的区别,创建线程有几种方式,线程有几种状态,等等。
接下来自然就会引出线程池,Lock,Synchronized,JUC的各种并发包。然后就会引出 AQS、CAS、JMM、JVM等偏底层原理,一环扣一环。
这一节我们不聊其他的,只说创建线程有几种方式。
是不是感觉非常简单,不就是那个啥啥那几种么。
其实不然,只有我们给面试官解释清楚了,并加上我们自己的理解,才能在面试中加分。
分类:
编程语言 时间:
2020-10-31 01:26:55
阅读次数:
15
来源:codeceo http://www.codeceo.com/javamemorymodel.html JMM简介 Java Memory Model简称JMM, 是一系列的Java虚拟机平台对开发者提供的多线程环境下的内存可见性、是否可以重排序等问题的无关具体平台的统一的保证。(可能在术语上 ...
分类:
编程语言 时间:
2020-10-22 22:33:13
阅读次数:
20
"The Java Language Specification Java SE 12 Edition" 17.4.4 Synchronization OrderEvery execution has a synchronization order. A synchronization order ...
分类:
编程语言 时间:
2020-10-12 20:09:47
阅读次数:
29
JMM 硬件层数据一致性 intel 用MESI https://www.cnblogs.com/z00377750/p/9180644.html 现代CPU的数据一致性实现 = 缓存锁 + 总线锁【早期的唯一实现】 读取缓存以cache line为基本单位,目前64bytes 位于同一缓存行的两个 ...
分类:
其他好文 时间:
2020-09-15 20:52:01
阅读次数:
30
1、计算机结构 (1)出现 冯诺依曼,提出计算机由五大组成部分,输入设备,输出设备存储器,控制器,运算器 (2)CPU 中央处理器,是计算机的控制和运算的核心,我们的程序最终都会变成指令让CPU去执行,处理程序中的数据。 (3)内存 我们的程序都是在内存中运行的,内存会保存程序运行时的数据,供CPU ...
分类:
编程语言 时间:
2020-08-27 13:11:15
阅读次数:
60
什么是Java内存模型 Java虚拟机规范中试图定义一种Java内存模型(Java Memory Model,JMM)来屏蔽掉各种硬件和操作系统的访问差异,以实现让Java程序在各种平台下都能达到一致的内存访问效果。在此之前,主流程序语言(如C/C++等)直接使用物理硬件和操作系统的内存模型,因此, ...
分类:
编程语言 时间:
2020-08-04 09:52:44
阅读次数:
66
Java内存模型(Java Memory Model,JMM)是java虚拟机规范定义的,用来屏蔽掉java程序在各种不同的硬件和操作系统对内存的访问的差异,这样就可以实现java程序在各种不同的平台上都能达到内存访问的一致性。可以避免像c等直接使用物理硬件和操作系统的内存模型在不同操作系统和硬件平 ...
分类:
编程语言 时间:
2020-07-24 22:01:52
阅读次数:
78
2.1 创建环境 打开终端,进入 Code 目录,并将其作为我们的工作目录。 $ cd Code 2.2 下载MyQR $ sudo pip3 install MyQR 2.3 下载所需资源文件并解压 Code/ $ wget http://labfile.oss.aliyuncs.com/cour ...
分类:
编程语言 时间:
2020-07-24 16:40:22
阅读次数:
88
JMM和底层实现原理 1.并发编程领域的关键问题 1.1 线程之间的通信 线程的通信是指线程之间以何种机制来交换信息。在编程中,线程之间的通信机制有两种,共享内存和消息传递。在共享内存的并发模型里,线程之间共享程序的公共状态,线程之间通过写-读内存中的公共状态来隐式进行通信,典型的共享内存通信方式就 ...
分类:
其他好文 时间:
2020-07-20 22:34:55
阅读次数:
65