JVM 集合类 多线程
文章平均质量分 94
认真工作,用心生活
南征_北战
这个作者很懒,什么都没留下…
展开
-
集合类-hashMap
部分内容来源公众号:楚狂声哥HashMap转载自:https://mp.weixin.qq.com/s/TZWsVlE5HOOyf24SktUv1QHashMap 也算是面试常客了。HashMap 几乎是我们在 Java 开发中最常用的类之一,它基于 Hash 表实现了一个 Map 结构,使得我们可以根据 Key 对 Value 进行快速查找,时间复杂度接近。HashMap 允许 null 键和 null 值,其中 null 键的 hash 值记为 0。除此以外,HashMap 是线程不安..原创 2021-02-24 21:52:37 · 211 阅读 · 0 评论 -
JVM -- 直接内存
为什么要讲这个,因为JDK8及其之后元空间隔离出来直接使用本地内存了。直接内存概述不是虚拟机运行时数据区的一部分,也不是《Java虚拟机规范》中定义的内存区域。 直接内存是在Java堆外的、直接向系统申请的内存区间。 来源于NIO(JDK1.4引入),通过存在堆中的DirectByteBuffer(该类的对象存在直接内存中,那之前说的所有new出来的对象都在堆中的说法有误?)操作本地内存。 通常,访问直接内存的速度会优于Java堆。即读写性能高。因此出于性能考虑,读写频繁的场合可能会考虑使原创 2021-02-18 17:37:24 · 243 阅读 · 0 评论 -
JVM -- 方法区、对象的实例化 内存布局 与访问定位
栈、堆、方法区的交互关系方法区的理解《Java虚拟机规范》中明确说明:“尽管所有的方法区在逻辑 上是属于堆的一部分,但一些简单的实现可能不会选择去进行垃圾收集或者进行压缩。”但对于HotSpotJVM而言,方法区还有一个别名叫做Non-Heap (非堆),目的就是要和堆分开。方法区(Method Area)与Java堆一 样, 是各个线程共享的内存区域。 方法区在JVM启动的时候被创建,并且它的实际的物理内存空间中和Java堆区一样都可以是不连续的。 方法区的大小,跟堆空间一样,可以选择原创 2021-02-13 19:57:59 · 535 阅读 · 0 评论 -
JVM -- 本地方法接口,本地方法栈,学习路线,堆
本地方法接口什么是本地方法简单地讲,一个Native Method就是一个Java调用非Java代码的接口。一个Native Method是这样一个Java方法:该方法的实现由非Java语言实现,比如C。这个特征并非Java所特有,很多其它的编程语言都有这一机制,比如在C++中,你可以用extern "C"告知C++编译器去调用一个c的函数。在定义一个native method时,并不提供实现体(有些像定义一个Javainterface) ,因为其实现体是由非java语言在外面实现的(nati原创 2021-01-31 21:11:42 · 156 阅读 · 0 评论 -
JVM -- 运行时数据区,PC寄存器,虚拟机栈
JVM内存布局内存是非常重要的系统资源,是硬盘和CPU的中间仓库及桥梁,承载着操作系统和应用程序的实时运行。JVM内存布局规定了Java在运行过程中内存申请、分配、管理的策略,保证了JVM的高效稳定运行。不同的JVM对于内存的划分方式和管理机制存在着部分差异。结合JVM虚拟机规范,来探讨一下经典的JVM内存布局,如下:Java虚拟机定义了若干种程序运行期间会使用到的运行时数据区,其中有一些会随着虚拟机启动而创建,随着虚拟机退出而销毁。另外一些则是与线程一一对应的,这些与线程对应的数据区域..原创 2021-01-26 16:08:39 · 185 阅读 · 0 评论 -
JVM -- 跨语言的平台,位置与结构,指令集架构,生命周期,发展历程,内存结构,类加载子系统
一些有一定工作经验的开发人员,打心眼儿里觉得sSM、微服务等上层技术才是重点,基础技术并不重要,这其实是一种本末倒置的“病态”。如果我们把核心类库的 APT 比做数学公式的话,那么、Java 虚拟机的知识就好比公式的推导过程。架构师每天都在思考什么?应该如何让我的系统更快? 如何避免系统出现瓶颈?垃圾收集机制为我们打理了很多繁琐的工作,大大提高了开发的效率,但.是,垃圾收集也不是万能的,懂得JVM内部的内存结构、工作机制,是设计高扩展性应用和诊断运行时问题的基础,也是Java :工程师进阶的必原创 2021-01-21 21:13:03 · 243 阅读 · 1 评论