本文共 1272 字,大约阅读时间需要 4 分钟。
本文Chat | Java与底层操作系统的交互细节
作者 | 小强
编辑 | 林瑟
下层基础决定上层建筑,只有扎实的基础知识,熟练掌握底层原理,才能在技术道路上走的更远,更深。
Java 作为一门高级语言也一样,你了解什么是缓存伪共享么?你了解 RocketMQ 为提升文件读写速度做了哪些优化么?你知道为什么大家总建议线程池大小设置为 CPU 核心 * 2 ,这样合理么?
本场 Chat 全文将介绍以下内容:
CPU 访问内存
虚拟存储
进程中断
系统调用
Java 内存映射
Java 对象内存布局
Java 线程同步
Unsafe 类方法分析
根据冯·诺依曼思想,计算机采用二进制作为数制基础,必须包含:运算器、控制器、存储设备,以及输入输出设备,如下图所示。
(该图来源于百度)
02
我们先来分析 CPU 的工作原理
现代 CPU 芯片中大都集成了:控制单元、运算单元、存储单元。控制单元是 CPU 的控制中心, CPU 需要通过它才知道下一步做什么,也就是执行什么指令,控制单元又包含:指令寄存器(IR ),指令译码器( ID )和操作控制器( OC )。
当程序被加载进内存后,指令就在内存中了,这个时候说的内存是独立于 CPU 外的主存设备,也就是 PC 机中的内存条。指令指针寄存器 IP 指向内存中下一条待执行指令的地址,控制单元根据 IP 寄存器的指向,将主存中的指令装载到指令寄存器。
这个指令寄存器也是一个存储设备,不过它集成在 CPU 内部,指令从主存到达 CPU 后只是一串 010101 的二进制串,还需要通过译码器解码,分析出 操作码是什么、操作数在哪。之后就是具体的运算单元进行算术运算(加减乘除)、逻辑运算(比较、位移)。
而 CPU 指令执行过程大致为:取址(去主存获取指令放到寄存器)、译码(从主存获取操作数放入高速缓存 L1 )、执行(运算)。
这里解释下上图中 CPU 内部集成的存储单元 SRAM ,正好和主存中的 DRAM 对应,RAM 是随机访问内存,就是给一个地址就能访问到数据;而磁盘这种存储媒介必须顺序访问。
一行代码能够执行,必须要有可以执行的上下文环境。
包括指令寄存器、数据寄存器、栈空间等内存资源,然后这行代码必须作为一个执行流能够被操作系统的任务调度器识别,并给他分配 CPU 资源。当然这行代码所代表的指令必须是 CPU 可以解码识别的,所以一行 Java 代码必须被解释成对应的 CPU 指令才能执行。
由于原文很长,大量代码无法全部在本文中展示,感兴趣的同学扫下方二维码可以查看完整全文和代码部分。
扫码查看全文
▼
最后,告诉大家一个赚取返现的小窍门
扫描上方图片的二维码之后如下操作
分享卡说明:每邀请一位好友购买,您将获得 Chat 定价的 25% 作为邀请奖励。大家可以生成自己专属的邀请卡,保存下来推荐给有需要的盆友~学习的同时还能赚到返现哦!!
点击阅读原文,订阅本场 Chat 学习,一起赚返现!
转载地址:http://luspi.baihongyu.com/