Java底层实现 - CPU术语

1.内存屏障(memory barriers)是一组处理器指令,用于实现对内存操作的顺序限制

2.缓冲行(cache line)CPU高速缓存中可以分配的最小存储单位。处理器填写缓存行时

会加载整个缓存行,现代CPU需要执行几百次CPU指令

3.原子操作(atomic operations)不可中断的一个或一系列操作

4.缓存行填充(cache line fill)当处理器识别到从内存中读取操作数是可缓存的,处理器

填写整个高速缓存行到适当的缓存(L1,L2,L3的或所有)

5.缓存命中(cache hit)如果进行高速缓存行填充操作的内存位置仍然是下次处理器访问的

地址时,处理器从缓存中读取操作数,而不是从内存读取

6.写命中(write hit)当处理器将操作数写回到一个内存缓存的区域时,它首先会检查这个

缓存的内存地址是否存在行中,如果存在一个有效的缓存行,则处理器将这个操作数写回到缓存,

而不是写回到内存,这个操作被称为写命中。

7.写缺失(write misses the cache)一个有效的缓存行被写入到不存在的内存区域

8.比较并交换(compare and swap)CAS操作需要输入两个数值,一个旧值(期望操作前的值)

和一个新值,在操作期间先比较旧值有没有发生变化,如果没有发生变化,才交换成新值,发生了变化

则不交换

9.CPU流水线(CPU pipeline)CPU流水线的工作方式就像工业生产上的装配流水线,在CPU中由5-6个

不同功能的电路单元组成一条指令处理流水线,然后将一条X86指令分成5-6步后再由这些电路单元分别执行,

这样就能实现一个CPU时钟周期完成一条指令,因此提高CPU的运算速度

10.内存顺序冲突(Memory order violation)内存顺序冲突一般是由假共享引起的,假共享是指多个CPU同时修改

一个缓存行的不同部分引起其中一个CPU的操作无效,当出现这个内存顺序冲突时,CPU必须清空流水线

IT技术和行业交流群 417691667

时间: 2024-10-13 20:06:58

Java底层实现 - CPU术语的相关文章

1.2、Java“白皮书”的关键术语

Java"白皮书"的关键术语 1.简单性 为了便于系统更易于理解,Java在设计的时候尽量可能地接近C++,但是Java提出了C++中许多很少使用.难以理解.易混淆的特性.可以说Java语法是C++语法的一个"纯净"版本.Java中没有头文件.指针运算(甚至指针语法).结构.联合.操作符重载.虚基类等. 2.面向对象 Java是一个完全面向对象的编程语言,它的面向对象特性与C++旗鼓相当.Java与C++的主要不同点在于多重继承,在Java中,取而代之的是更简单的接

java底层学习

额,马上就要面试了,Java的底层肯定是需要了解的.网上找了找java的底层文章,做个记号.java底层主要是类的加载.连接和初始化. 本文主要分为四个方面: (1)java底层概述 (2)new和newInstance()方法的区别 (3)深入探讨java的加载机制 (4)一个完整java程序冲Javaxxx.class执行的完整过程 四个部分都是来自网上的资料,四个部分看完,应该对java的底层有些了解了. 下面文字来自<疯狂java讲义>: 1.类的加载.连接和初始化 当系统主动使用某个

利用JMX统计远程JAVA进程的CPU和Memory

从JAVA 5开始,JDK提供了一些JVM检测的API,这就是有名的java.lang.management 包,包里提供了许多MXBean的接口类,可以很方便的获取到JVM的内存.GC.线程.锁.class.甚至操作系统层面的各种信息,本文就简单的介绍 一种利用JMX对JAVA进程进行CPU.堆内存使用的监控.可能有人会觉得没必要这样做,因为用jconsole之类的工具都能做到,而且会比本文的例 子更详细.但是有些时候将console不一定能监控到作为系统服务的java进程,我最近就不得不自己

java 程序消耗 cpu 100% 查找方法

问题原因:由于HashMap是非线程安全的,在多线程访问时,造成死循环. 查找问题方法: 1. Java代码   top 找出最耗费cpu的进程号 如:27377 2. Java代码   top -p 27377 -H 找出此进程下的所有线程,然后找出最耗cpu线程号 如:27433 3. Java代码   python  hex(27433) 将十进制数转为16进制 如:0x6b29 4. Java代码   jstack 27377 >cpu.log 将此进程号的Java堆栈信息打印到文件中

Java底层代码实现单文件读取和写入(解决中文乱码问题)

需求: 将"E:/data/车站一次/阿坝藏族羌族自治州.csv"文件中的内容读取,写入到"E:/data//车站一次.csv". 代码: public class FileOpe { public static void main(String[] args) { sigle(); } public static void sigle(){ BufferedReader bufr = null; BufferedWriter bufw = null; try {

Java底层代码实现多文件读取和写入

需求: "E:/data/"目录下有四个文件夹,如下: 每个文件夹下有几个.csv文件,如下: 将每个文件夹下的.csv文件合并成一个以该文件夹命名的.csv文件. 做法: 找到"E:/data"这个目录,循环读取目录下的四个文件夹: 针对每个文件夹,循环读取目录下的文件列表: 将读取的文件写入要合并的文件中. 代码: public class FileOperation { public static void main(String[] args) { comb

生产环境下JAVA进程高CPU占用故障排查

问题描述:生产环境下的某台tomcat7服务器,在刚发布时的时候一切都很正常,在运行一段时间后就出现CPU占用很高的问题,基本上是负载一天比一天高. 问题分析:1,程序属于CPU密集型,和开发沟通过,排除此类情况.2,程序代码有问题,出现死循环,可能性极大. 问题解决:1,开发那边无法排查代码某个模块有问题,从日志上也无法分析得出.2,记得原来通过strace跟踪的方法解决了一台PHP服务器CPU占用高的问题,但是通过这种方法无效,经过google搜索,发现可以通过下面的方法进行解决,那就尝试下

Java内存、CPU占用率过高

windows下揪出java程序占用cpu很高的线程 并找到问题代码 死循环线程代码 linux下查找java进程占用CPU过高原因 Java 占用CPU使用率很高的分析 记一次线上Java程序导致服务器CPU占用率过高的问题排除过程

博洁在线商城APP开发公司、java底层

进入这个革命式变化时代,作为消费者在以往的生产消费环节中所扮演的消费角色也将得以转变,升级成为消费商.如从目前迅速发展的微信,从其逐渐显示出的巨大威力和渗透力中不难发现,这样一种新的消费模式--"消费商"正在逐渐形成,并迅速扩大影响力. 博洁在线商城APP开发公司:(张丽185-6541.3369微.电)博洁在线模式,博洁在线APP,博洁在线商城定制  APP系统java底层构架分析: 1.在Java NIO的技术范畴中内存映射文件是一种高效的做法,可以用于缓存中存储的冷/热数据分离,