皮皮网
皮皮网

【插件源码开源】【团委官网源码】【mybatis源码暴力解析】serialgc源码解析

时间:2025-01-08 18:25:39 来源:白鹤翔 架构师 源码

1.这究竟是源码为什么呢?都说JVM能实际使用的内存比-Xmx指定的少,头大
2.java平台对于软件开发编程的影响作用?

serialgc源码解析

这究竟是为什么呢?都说JVM能实际使用的内存比-Xmx指定的少,头大

       这确实是个挺奇怪的问题,特别是解析当最常出现的几种解释理由都被排除后,看来JVM并没有耍一些明显的源码小花招:

       要弄清楚这个问题的第一步就是要明白这些工具的实现原理。通过标准APIs,解析插件源码开源我们可以用以下简单语句得到可使用的内存信息。

       而且确实,源码现有检测工具底层也是解析用这个语句来进行检测。要解决这个问题,源码首先我们需要一个可重复使用的解析测试用例。因此,源码我写了下面这段代码:

       这段代码通过将new int[1__]置于一个循环中来不断分配内存给程序,解析然后监测JVM运行期的源码团委官网源码当前可用内存。当程序监测到可用内存大小发生变化时,解析通过打印出Runtime.getRuntime().maxMemory()返回值来得到当前可用内存尺寸,源码输出类似下面语句:

       实际情况也确实如预估的解析那样,尽管我已经给JVM预先指定分配了2G对内存,源码在不知道为什么在运行期有M内存不见了。mybatis源码暴力解析你大可以把 Runtime.getRuntime().maxMemory()的返回值2,,K 除以来转换成MB,那样你将得到1,M,正好和M差M。

       在成功重现了这个问题之后,我尝试用使用不同的选股源码编码GC算法,果然检测结果也不尽相同。

       除了G1算法刚好完整使用了我预指定分配的2G之外,其余每种GC算法似乎都不同程度地丢失了一些内存。

       现在我们就该看看在JVM的源代码中有没有关于这个问题的解释了。我在CollectedHeap这个类的指标评判线源码源代码中找到了如下的解释:

       我不得不说这个答案藏得有点深,但是只要你有足够的好奇心,还是不难发现的:有时候,有一块Survivor区是不被计算到可用内存中的。

       明白这一点之后问题就好解决了。打开并查看GC logging 信息之后我们发现,在Serial,Parallel以及CMS算法回收过程中丢失的那些内存,尺寸刚好等于JVM从2G堆内存中划分给Survivor区内存的尺寸。例如,在上面的ParallelGC算法运行时,GC logging信息如下:

       由上面的信息可以看出,Eden区被分配了,K,两个Survivor区都被分配到了,K,老年代(Old space)则被分配了1,,K。把Eden区、老年代以及一个Survivor区的尺寸求和,刚好等于2,,K,说明丢失的那M(,K)确实就是剩下的那个Survivor区。

       总结而言,当JVM在运行时报告的可使用内存小于-Xmx指定的内存时,差值通常对应于一块Survivor区的大小。对于不同的GC算法,这个差值可能有所不同。

java平台对于软件开发编程的影响作用?

       éšç€äº’联网的不断发展,java编程语言的严谨性和完整性都得到了大幅度的提升。今天,电脑培训就一起来了解一下,关于java编程的一些其他知识体系。希望通过对本文的阅读,大家能够清楚的了解java编程语言的开发技术知识。

       Java本身是一种面向对象的语言,显著的特性有两个方面,一是所谓的“一次编译,到处执行”(Compileonce,runanywhere),能够非常容易地获得跨平台能力;另外就是垃圾收集(GC,GarbageCollection),Java通过垃圾收集器(GarbageCollector)回收分配内存,大部分情况下,程序员不需要自己操心内存的分配和回收。

       æˆ‘们日常会接触到JRE(JavaRuntimeEnvironment)或者JDK(JavaDevelopmentKit)。JRE,也就是Java运行环境,包含了JVM和Java类库,以及一些模块等。而JDK可以看作是JRE的一个超集,提供了更多工具,比如编译器、各种诊断工具等。

       å¯¹äºŽâ€œJava是解释执行”这句话,这个说法不太准确。我们开发的Java的源代码,先通过Javac编译成为字节码(bytecode),然后,在运行时,通过Java虚拟机(JVM)内嵌的解释器将字节码转换成为终的机器码。但是常见的JVM,比如我们大多数情况使用的OracleJDK提供的HospotJVM,都提供了JIT(Just-In-Time)编译器,也就是通常所说的动态编译器,JIT能够在运行时将热点代码编译成机器码,这种情况下部分热点代码就属于编译执行,而不是解释执行了。

       å¯¹äºŽJava平台的理解,可以从很多方面简明扼要地谈一下,例如:Java语言特性,包括泛型、Lambda等语言特性;基础类库,包括集合、IO/NIO、网络、并发、安全等基础类库。对于我们日常工作应用较多的类库,面试前可以系统化总结一下,有助于临场发挥。

       æˆ–者谈谈JVM的一些基础概念和机制,比如Java的类加载机制,常用版本JDK(如JDK8)内嵌的Class-Loader,例如Bootstrap、Application和ExtensionClass-loader;类加载大致过程:加载、验证、链接、初始化(这里参考了周志明的《深入理解Java虚拟机》,非常棒的JVM上手书籍);自定义Class-Loader等。还有垃圾收集的基本原理,常见的垃圾收集器,如SerialGC、ParallelGC、CMS、G1等,对于适用于什么样的工作负载好也心里有数。这些都是可以扩展开的领域,我会在后面的专栏对此进行更系统的介绍。

       å½“然还有JDK包含哪些工具或者Java领域内其他工具等,如编译器、运行时环境、安全工具、诊断和监控工具等。这些基本工具是日常工作效率的保证,对于我们工作在其他语言平台上,同样有所帮助,很多都是触类旁通的。

更多内容请点击【探索】专栏