IDEA 2024的零卡死配置

news/2025/9/27 17:04:44/文章来源:https://www.cnblogs.com/georgewing/p/19115313

IDEA 2024的零卡死配置

用了苹果container跑Linux之后,IDEA 2024 用着用着就卡死,这是苹果 Silicon M1 Max专属JDK 8 的零卡死配置。

JDK版本配置

IDEA 2024在默认情况下 Project 的 Language level 会从JDK22开始的,这样,我们一般打开project的时候需要将JDK版本设置为8。通过 File → Project Structure → Project 把JDK的相关配置设为JDK8版本即可。

maven配置

IDEA 2024在默认情况下 maven使用的是3.9版本,可能需要通过Settings → Build, Execution, Deployment → Build Tools → Maven设置为我们当前所用的maven版本。

同时也建议去掉Work offline这个选项,关闭离线模式:

侧边栏跟随打开选中的文件

IDEA2024点击Tab栏上的文件,左侧的侧边栏不会跟随打开选中的,我们可以通过侧边栏的behavior设置勾选下列3个选项:

文件搜索

IDEA2024是双击Shift键快捷搜索文件的。如下图所示,输入关键字,对于all是可以看到所有的选项,然后点击preview会展开搜索项的预览情况:

如果只想要搜索类文件,则可以通过filter进行筛选。

还可以通过点击tab进行个性化筛选。比如,查询All Places(项目中的类)或者是Project adn Libraries(项目和类库中的),如下图所示:

函数的快速定位

IDEA 2024对于函数比如FutureTask的源码阅读,可以看到如下所示,无论怎样滚动代码,这个方法以及类的定义始终浮于上方。

也就是说,如果这个函数体很长,IDEA2024对此进行了优化的。

查看变量调用

IDEA 2024中,可以通过Command + B快捷键查看变量的调用。如果在项目中没有用到这个变量,那么可以用Command + Option + F7快捷键来设置检索范围:

想要查看方法或者是变量调用详情,可以先把光标停在方法或者变量上,然后通过Option + F7快捷键来查看调用详情。

以FutureTask的run方法为例,可以看到对其调用的检索,通过左边就可以定位到调用,右边就是调用的详情。

查看TODO项

要进行代码的todo项的检索,可以通过view→Tool Windows→TODO来查看:

然后在 todo 栏能看到在项目中所有的 todo 注释:

源码调试

IDEA 2024可以快速跳到下一个断点,也就是说,如果在这有几个函数,先跳过,直接到最后一行输出。只需要点击这个Run to cursor,最终就会定位到我们想要的位置上。

idea.vmoptions 配置调整

JVM配置是针对10核CPU (8性能核 + 2效率核) + 32GB统一内存的:

# 内存配置 - M1 Max统一内存架构优化
-Xms5120m
-Xmx5120m# 元空间配置
-XX:MetaspaceSize=512m
-XX:MaxMetaspaceSize=1024m# 代码缓存 - M1 Max可以用更大的缓存
-XX:ReservedCodeCacheSize=1024m# GC策略 - M1 Max下ParallelGC表现最佳
-XX:+UseParallelGC
-XX:+UseParallelOldGC
-XX:ParallelGCThreads=10
-XX:ConcGCThreads=3# 编译器优化 - 充分利用10核处理器
-XX:CICompilerCount=8
-XX:+TieredCompilation
-XX:TieredStopAtLevel=4# M1 Max特殊优化
-XX:+AggressiveOpts
-XX:+UseFastAccessorMethods
-XX:+UseCompressedOops
-XX:+UseCompressedClassPointers# 性能调优
-XX:SoftRefLRUPolicyMSPerMB=50
-XX:+UseStringDeduplication
-XX:NewRatio=2# Apple Silicon专属参数
-Dfile.encoding=UTF-8
-Djava.net.preferIPv4Stack=true
-Dcom.apple.macos.useScreenMenuBar=true# 调试和监控
-XX:+HeapDumpOnOutOfMemoryError
-XX:-OmitStackTraceInFastThrow
-XX:+IgnoreUnrecognizedVMOptions
-XX:+PrintGCDetails
-XX:+PrintGCTimeStamps# JetBrains IDE专属优化
-Dsun.io.useCanonCaches=false
-Djdk.http.auth.tunneling.disabledSchemes=""
-XX:+HeapDumpOnOutOfMemoryError
-XX:HeapDumpPath=~/Desktop/# UI渲染优化 (Retina显示器)
-Dawt.useSystemAAFontSettings=lcd
-Dswing.aatext=true
-Dsun.java2d.renderer=sun.java2d.marlin.MarlinRenderingEngine

上面的配置中:

  • 堆内存:5GB,我用Stats.app监控着RAM(内存)的占用率为83%左右,比调整配置前多了10%,除了idea本身进程的5GB,还是2个各用了至少1GB的java进程。

  • 编译线程:8个。

  • GC线程:10个,充分利用M1核心。

  • 稳定性:由G1GC调整为ParallerGC,稳定大幅提升。

小结

原先的配置导致卡死的原因主要是:

  • JDK 8配置成G1GC在M1 Max上不够稳定。

  • 编译线程数严重不足,浪费M1性能。

现在这配置是零卡死风险了。

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

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

相关文章

Python + MediaPipe 手势绘画高级应用:从基础到创意交互 - 实践

Python + MediaPipe 手势绘画高级应用:从基础到创意交互 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "C…

有建设网站的软件吗吉林市最新消息今天

这是连续剧般的文章,请关注,持续更新中... 系列文章: http://t.csdnimg.cn/Os83Qhttp://t.csdnimg.cn/Os83Q这篇文章将我们的reactro转变成http服务器... HTTP HTTP介绍 HTTP是一个基于TCP通信协议的基础上的应用层协议。接下来我们需要解析HTTP请求消息…

网站怎么做百度认证做照片有那些网站好

这篇文章主要介绍了opencv python图像梯度实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下一阶导数与Soble算子二阶导数与拉普拉斯算子图像边缘:Soble算子:二阶导数:拉…

天津智能网站建设制作桓台网站建设

转自:进阶 JavaScript 必知的 33 个点【进阶必备】 进阶 JavaScript 必知的 33 个点【进阶必备】 Original 前端小菜鸡之菜鸡互啄 前端开发爱好者 2022-04-11 08:32 收录于话题#javaScript进阶1个 点击下方“前端开发爱好者”,选择“设为星标” 第一…

Crypto 2021 s Accepted papers

转载自:https://crypto.iacr.org/2021/acceptedpapers.phpAccepted Papers 接收论文These papers are listed in order of submission.这些论文按提交顺序排列。White Box Traitor Tracing白盒背叛追踪 Mark Zhand…

详细介绍:【数据结构】哈希表(Hash Table)详解

详细介绍:【数据结构】哈希表(Hash Table)详解2025-09-27 16:57 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; displa…

Github 12.3kstar, 3分钟起步做中后台?Go+Vue 脚手架,把权限、代码生成、RBAC 都封装好了

嗨,我是小华同学,专注解锁高效工作与前沿AI工具!每日精选开源技术、实战技巧,助你省时50%、领先他人一步。👉免费订阅,与10万+技术人共享升级秘籍!go-admin 是一个基于 Gin + Vue 的前后端分离权限管理脚手架,…

电子商务网站建设行情建设网站的网站叫什么男

0 前言 无人驾驶技术是机器学习为主的一门前沿领域,在无人驾驶领域中机器学习的各种算法随处可见,今天学长给大家介绍无人驾驶技术中的车道线检测。 1 车道线检测 在无人驾驶领域每一个任务都是相当复杂,看上去无从下手。那么面对这样极其…

河南城乡建设部网站首页中国十大购物网站排行榜

题目链接 洛谷P4559 题解 只会做\(70\)分的\(O(nlog^2n)\) 如果本来就在区间内的人是不用动的,区间右边的人往区间最右的那些空位跑,区间左边的人往区间最左的那些空位跑 找到这些空位就用二分 主席树 理应可以在主席树上的区间二分而做到\(O(nlogn)\)&…

苏州app制作大型网站的优化方法

网络连通性测试与网络命令验证实验报告西工大计算机网络原理实验报告网络原理实验报告实验名称: 网络连通性测试与网络命令验证 日期: 2015.11.09 班级:学号: 姓名:【一】 预习内容5个常用网络命令&#xf…

北京网站seo哪家公司好wordpress 在线教育主题

存储引擎: 存储引擎是Inndb。它支持行级锁,以及表级锁, 支持事务操作, 需要主键,若未声明主键,则会寻找表中的 not null 以及 unique 修饰的字段。若表中无此类字段,会隐式生成字段。 索引&…

网站需求清单如何用c 做网站

文章目录 一、softmax函数1.1 引入指数形式的优点1.2 引入指数形式的缺点 二、交叉熵损失函数2.1 交叉熵损失函数2.2 softmax与交叉熵损失 参考资料 一、softmax函数 softmax用于多分类过程中,它将多个神经元的输出,映射到(0,1)区…

250927

目录JT-JY5T1S1-1JT-JY5T1S1-2FT-(JY&VOAs) JT-JY5T1S1-1Good afternoon, Dream Time Travel, How can i help you? Oh, hello, i am interested in the hoilday you offer along the coast near here. Yes, we o…

Ti 毫米波雷达FFT的缩放问题

struct DPU_RangeProcHWA_FFTtuning_t{ /*! @brief Specify amount of right (divide) shift to apply to convert HWA internal 24-bit Range FFT output to 16-bit RadarCube. User should adjust this based on th…

完整教程:多线程——单例模式

完整教程:多线程——单例模式pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco"…

A Twisty Movement

CF933A A Twisty Movement 简化题目 给定一个有 \(1\),\(2\) 两个数字组成的数组中,选择一个子串,将 \(1\) 变成 \(2\),将 \(2\) 变成 \(1\),求出变化后的序列的最长上升子序列。 思路 简单的情况 如果没有变换操…

佛山新网站建设渠道天津工程网站建设

MySQL 中的集群部署方案 前言 这里来聊聊,MySQL 中常用的部署方案。 MySQL Replication MySQL Replication 是官方提供的主从同步方案,用于将一个 MySQL 的实例同步到另一个实例中。Replication 为保证数据安全做了重要的保证,是目前运用…

山东网站建设设计小清新个人网站

七、高并发内存池–Page Cache 7.1 PageCache的工作原理 PageCache是以span的大小(以页为单位)和下标一一对应为映射关系的哈希桶,下标是几就说明这个哈希桶下挂的span的大小就是几页的,是绝对映射的关系。因为PageCache也是全局只有唯一一个的&#x…

完整教程:iOS 混淆与反调试反 Hook 实战,运行时防护、注入检测与安全加固流程

完整教程:iOS 混淆与反调试反 Hook 实战,运行时防护、注入检测与安全加固流程pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-f…

3.WPF - 依赖属性 - 实践

3.WPF - 依赖属性 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", &q…