查看并解析当前jdk的垃圾收集器

概述:复习的时候,学看一下。

命令:

-XX:+PrintCommandLineFlags 

打开idea,配置jvm

把上面命令输入jvm options中即可。

举例代码

这个代码的解析,我上篇文章有写,这个跟本文没有任何关系:

hutool工具的简单使用-CSDN博客

pom文件:

  <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.24</version></dependency>

示例代码:

package org.cyl.test04;import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.date.DateTime;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.io.FileUtil;
import cn.hutool.core.io.resource.ClassPathResource;
import cn.hutool.core.lang.Console;
import cn.hutool.core.util.CharsetUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.SecureUtil;
import cn.hutool.crypto.asymmetric.KeyType;
import cn.hutool.crypto.asymmetric.RSA;
import cn.hutool.http.HttpUtil;import java.io.File;
import java.util.List;public class HutoolExample {public static void main(String[] args) {// 字符串操作String str = "Hutool is a tool for Java.";String result = StrUtil.sub(str, 0, 10);Console.log("SubString: {}", result);// 文件操作File file = FileUtil.file("D:\\csdnwork\\test04\\src\\main\\resources\\static\\text.txt");FileUtil.writeUtf8String("Hello Hutool", file);// 集合操作List<String> list1 = CollUtil.newArrayList("Hutool", "Java", "Tool");List<String> list2 = CollUtil.newArrayList("Easy", "Effective");List<String> newList = (List<String>) CollUtil.addAll(list1, list2);Console.log("New List: {}", newList);// 加密String test = SecureUtil.md5("Hello Hutool");Console.log("MD5: {}", test);// 加密RSA rsa = new RSA();String originalText = "Hello Hutool";byte[] encryptResult = rsa.encrypt(originalText, KeyType.PublicKey);Console.log("Encrypted: {}", encryptResult);// 解密byte[] decryptResult = rsa.decrypt(encryptResult, KeyType.PrivateKey);String decryptedText = new String(decryptResult);Console.log("Decrypted: {}", decryptedText);// 日期时间处理String dateStr = "2022-01-22";Console.log("Date: {}", DateUtil.parse(dateStr));// 网络操作String response = HttpUtil.get("https://www.baidu.com");Console.log("HTTP Response: {}", response);// 读取Classpath下的资源文件ClassPathResource resource = new ClassPathResource("/static/index.html");String content = resource.readStr(CharsetUtil.CHARSET_UTF_8);Console.log("Resource Content: {}", content);}
}

运行查看:

解析结果

我用的是graalvm17

-XX:ConcGCThreads=3 -XX:+EnableJVMCIProduct -XX:G1ConcRefinementThreads=13 -XX:GCDrainStackTargetSize=64 -XX:InitialHeapSize=264819584 -XX:MarkStackSize=4194304 -XX:MaxHeapSize=4237113344 -XX:MinHeapSize=6815736 -XX:+PrintCommandLineFlags -XX:ReservedCodeCacheSize=251658240 -XX:+SegmentedCodeCache -XX:ThreadPriorityPolicy=1 -XX:-UnlockExperimentalVMOptions -XX:+UseCompressedClassPointers -XX:+UseCompressedOops -XX:+UseG1GC -XX:-UseLargePagesIndividualAllocation 

  • -XX:ConcGCThreads=3: 设置并发垃圾回收线程数为3。
  • -XX:+EnableJVMCIProduct: 启用JVMCI产品。
  • -XX:G1ConcRefinementThreads=13: 设置G1垃圾回收器的并发细化线程数为13。
  • -XX:GCDrainStackTargetSize=64: 设置GCDrain栈目标大小为64MB。
  • -XX:InitialHeapSize=264819584: 设置初始堆大小为264819584字节(约2.5GB)。
  • -XX:MarkStackSize=4194304: 设置标记栈大小为4194304字节(约4MB)。
  • -XX:MaxHeapSize=4237113344: 设置最大堆大小为4237113344字节(约4GB)。
  • -XX:MinHeapSize=6815736: 设置最小堆大小为6815736字节(约6.5MB)。
  • -XX:+PrintCommandLineFlags: 打印命令行标志。
  • -XX:ReservedCodeCacheSize=251658240: 设置保留代码缓存大小为251658240字节(约240MB)。
  • -XX:+SegmentedCodeCache: 启用分段代码缓存。
  • -XX:ThreadPriorityPolicy=1: 设置线程优先级策略为1。
  • -XX:-UnlockExperimentalVMOptions: 禁用实验性虚拟机选项。
  • -XX:+UseCompressedClassPointers: 使用压缩类指针。
  • -XX:+UseCompressedOops: 使用压缩普通对象指针。
  • -XX:+UseG1GC: 使用G1垃圾回收器。
  • -XX:-UseLargePagesIndividualAllocation: 禁用单独分配大页面。

查看G1垃圾回收器

都知道现在用的是G1收集器,命令。

-XX:+PrintCommandLineFlags -XX:+PrintGCDetails 

打印一下GCDetails.

  1. [0.006s][info ][gc] Using G1:表示正在使用G1垃圾收集器。
  2. [0.007s][info ][gc,init] Version: 17.0.9+11-LTS-jvmci-23.0-b21 (release):表示G1垃圾收集器的初始版本号为17.0.9+11-LTS-jvmci-23.0-b21。
  3. [0.007s][info ][gc,init] CPUs: 16 total, 16 available:表示总共有16个CPU核心可用。
  4. [0.007s][info ][gc,init] Memory: 16163M:表示JVM的总内存为16163兆字节(MB)。
  5. [0.007s][info ][gc,init] Large Page Support: Disabled:表示不支持大页(Large Page)。
  6. [0.007s][info ][gc,init] NUMA Support: Disabled:表示不支持NUMA(Non-Uniform Memory Access,非一致内存访问)。
  7. [0.007s][info ][gc,init] Compressed Oops: Enabled (Zero based):表示启用了压缩对象指针(Compressed Object Pointer),并且是基于零的索引。
  8. [0.007s][info ][gc,init] Heap Region Size: 2M:表示垃圾回收的一块区域的大小为2兆字节(MB)。
  9. [0.007s][info ][gc,init] Heap Min Capacity: 8M:表示堆的最小容量为8兆字节(MB)。
  10. [0.007s][info ][gc,init] Heap Initial Capacity: 254M:表示堆的初始容量为254兆字节(MB)。
  11. [0.007s][info ][gc,init] Heap Max Capacity: 4042M:表示堆的最大容量为4042兆字节(MB)。
  12. [0.007s][info ][gc,init] Pre-touch: Disabled:表示禁用预触摸(Pre-touch)。
  13. [0.007s][info ][gc,init] Parallel Workers: 13:表示并行工作线程的数量为13。
  14. [0.007s][info ][gc,init] Concurrent Workers: 3:表示并发工作线程的数量为3。
  15. [0.007s][info ][gc,init] Concurrent Refinement Workers: 13:表示并发整理工作线程的数量为13。
  16. [0.007s][info ][gc,init] Periodic GC: Disabled:表示禁用周期性垃圾收集(Periodic Garbage Collection)。
  17. [0.015s][info ][gc,metaspace] CDS archive(s) mapped at: [0x0000018e47000000-0x0000018e47bd0000-0x0000018e47bd0000), size 12386304, SharedBaseAddress: 0x0000018e47000000, ArchiveRelocationMode: 1.:表示CDS归档文件映射在地址范围[0x0000018e47000000-0x0000018e47bd0000-0x0000018e47bd0000),大小为12386304字节,共享基地址为0x0000018e47000000,归档重定位模式为1。
  18. [0.015s][info ][gc,metaspace] Compressed class space mapped at: 0x0000018e48000000-0x0000018e88000000, reserved size: 1073741824:表示压缩类空间映射在地址范围[0x0000018e48000000-0x0000018e88000000),保留大小为1GB。
  19. [0.015s][info ][gc,metaspace] Narrow klass base: 0x0000018e47000000, Narrow klass shift: 0, Narrow klass range: 0x100000000:表示窄类(Narrow Class)的基址为0x0000018e47000000,移位量为0,范围为从0x100000000到最大值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/642795.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++--enum--枚举

C/C枚举类型&#xff1a; 不限定作用域的枚举类型 关键字&#xff1a;enum 声明枚举类型&#xff0c;然后可以用枚举类型来定义变量(如同结构体)&#xff1a; enum Color{white,black,yellow}; {注意分号} Color color_type; color_type 变量的值只限于枚举类型Color中的值 枚…

深度学习|RCNNFast-RCNN

1.RCNN 2014年提出R-CNN网络&#xff0c;该网络不再使用暴力穷举的方法&#xff0c;而是使用候选区域方法&#xff08;region proposal method&#xff09;创建目标检测的区域来完成目标检测的任务&#xff0c;R-CNN是以深度神经网络为基础的目标检测的模型 &#xff0c;以R-C…

Hikvision综合安防管理平台files;.css接口存在任意文件读取漏洞 附POC软件

免责声明&#xff1a;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该文章仅供学习用途使用。 1. Hikvisi…

设计模式——1_6 代理(Proxy)

诗有可解不可解&#xff0c;若镜花水月勿泥其迹可也 —— 谢榛 文章目录 定义图纸一个例子&#xff1a;图片搜索器图片加载搜索器直接在Image添加组合他们 各种各样的代理远程代理&#xff1a;镜中月&#xff0c;水中花保护代理&#xff1a;对象也该有隐私引用代理&#xff1a;…

Jupyter Notebook安装使用教程

Jupyter Notebook 是一个基于网页的交互式计算环境&#xff0c;允许你创建和共享包含代码、文本说明、图表和可视化结果的文档。它支持多种编程语言&#xff0c;包括 Python、R、Julia 等。其应用场景非常广泛&#xff0c;特别适用于数据科学、机器学习和教育领域。它可以用于数…

vue element MessageBox.prompt this.$prompt组件禁止显示右上角关闭按钮,取消按钮,及点击遮罩层关闭

vue element MessageBox.prompt this.$prompt组件禁止或取消显示右上角关闭按钮&#xff0c;取消按钮&#xff0c;及点击遮罩层关闭 实现效果&#xff1a; 实现代码 MessageBox.prompt(请先完成手机号绑定, 系统提示, {confirmButtonText: 提 交,showClose: false,closeOnClic…

linux之安装配置VM+CentOS7+换源

文章目录 一、centos07安装二、CentOS 07网络配置2.1解决CentOS 07网络名不出现问题此博主的论文可以解决2.2配置&#xff08;命令: 【ip a】也可查看ip地址&#xff09; 三、使用链接工具链接CentOS进行命令控制四、换软件源 一、centos07安装 1、在vmvare中新建虚拟机 2、下…

Linux:动静态库的概念与制作使用

文章目录 动静态库基础认知动静态库基本概念静态库的制作库的概念包的概念 静态库的使用第三方库小结 动态库的制作动态库的使用动态库如何找到内容&#xff1f;小结 本篇要谈论的内容是关于动静态库的问题&#xff0c;具体的逻辑框架是建立在库的制作&#xff0c;库的使用&…

mysql INSERT数据覆盖现有元素(若存在)

INSERT...ON DUPLICATE KEY UPDATE的使用 如果指定了ON DUPLICATE KEY UPDATE&#xff0c;并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值&#xff0c;则会更新ON DUPLICATE KEY UPDATE关键字后面的字段值。 例如&#xff0c;如果列a被定义为UNIQUE&#xff0…

不要为了学习而学习

经常有朋友问我&#xff1a; 老师&#xff0c;从您这里学了很多方法&#xff0c;也一直想要改变自己&#xff0c;但总是没办法坚持下去&#xff0c;怎么办&#xff1f; 这个问题&#xff0c;我也很无奈啊。毕竟我也没办法飞到你身边&#xff0c;手把手把每一步都教给你。&…

Eyes Wide Shut? Exploring the Visual Shortcomings of Multimodal LLMs

大开眼界&#xff1f;探索多模态模型种视觉编码器的缺陷。 论文中指出&#xff0c;上面这些VQA问题&#xff0c;人类可以瞬间给出正确的答案&#xff0c;但是多模态给出的结果却是错误的。是哪个环节出了问题呢&#xff1f;视觉编码器的问题&#xff1f;大语言模型出现了幻觉&…

七八分钟快速用k8s部署springboot前后端分离项目

前置依赖 k8s集群&#xff0c;如果没有安装&#xff0c;请先安装 kubectl &#xff0c;客户端部署需要依赖 应用镜像构建 应用镜像构建不用自己去执行&#xff0c;相关镜像已经推送到docker hub 仓库&#xff0c;如果要了解过程和细节&#xff0c;可以看一下&#xff0c;否…

基于springboot+vue的足球青训俱乐部管理系统(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 研究背景…

C++逆向分析--虚函数(多态的前置)

先理解一件事&#xff0c;在intel汇编层面来说&#xff0c;直接调用和间接调用的区别。 直接调用语法&#xff1a; call 地址 硬编码为 &#xff1a;e8 间接调用语法: call [ ...] 硬编码为: FF 那么在C语法中&#xff0c;实现多态的前提是父类需要实现多态的成员…

「 网络安全术语解读 」通用攻击模式检举和分类CAPEC详解

引言&#xff1a;在网络安全领域&#xff0c;了解攻击者的行为和策略对于有效防御攻击至关重要。然而&#xff0c;攻击模式的描述和分类方式缺乏统一性和标准化。为了解决这个问题&#xff0c;MITRE公司创建了CAPEC标准&#xff0c;以提供一个共享和统一的攻击模式分类框架。 1…

一文让你彻底搞懂cookie和session产生漏洞的原理

首先让我们来看看登录的一般流程&#xff1a; 输入账号密码提交给后端&#xff1b;后端进行判断账号密码是否一致&#xff0c;这里的逻辑根据每个程序员的想法去写&#xff1b;如果通过2登录成功&#xff0c;跳转登录成功的页面&#xff1b; 如果通过2登录失败&#xff0c;跳转…

Tensorflow2.0笔记 - 范式norm,reduce_min/max/mean,argmax/min, equal,unique

练习norm,reduce_min/max,argmax/min, equal,unique等相关操作。 范数主要有三种&#xff1a; import tensorflow as tf import numpy as nptf.__version__#范数参考&#xff1a;https://blog.csdn.net/HiWangWenBing/article/details/119707541 tensor tf.convert_to_tensor(…

TensorRT英伟达官方示例解析(二)

系列文章目录 TensorRT英伟达官方示例解析&#xff08;一&#xff09; TensorRT英伟达官方示例解析&#xff08;二&#xff09; 文章目录 系列文章目录前言一、03-BuildEngineByTensorRTAPI1.1 建立 Logger&#xff08;日志记录器&#xff09;1.2 Builder 引擎构建器1.3 Netwo…

【GitHub项目推荐--Awesome-Go/Python/JavaScript/Java】【转载】

Awesome 译为令人惊叹的、极好的&#xff0c;GitHub 上有很多 Awesome 开头的开源项目。比如 Awesome-Go、Awesome-Python。 就像汇总常用的软件一样&#xff0c;GitHub上有大量的开源项目&#xff0c;开发者就会根据需要汇总一些常用的好用的资源&#xff0c;并且根据 Awesom…

OCP NVME SSD规范解读-7.TCG安全日志要求

在OCP NVMe SSD规格中&#xff0c;TCG的相关内容涉及以下几个方面&#xff1a; 活动事件记录&#xff1a; NVMe SSD需要支持记录TCG相关的持久事件日志&#xff0c;用于追踪固态硬盘上发生的与TCG安全功能相关的关键操作或状态变化&#xff0c;如启动过程中的安全初始化、密钥…