phpstorm内存分配学习

当PHPStorm运行卡顿时,可以通过调整内存配置来优化。主要涉及堆内存和非堆内存的设置,如-Xms和-Xmx用于设定堆内存初始和最大值,防止OutOfMemory错误。非堆内存的 PermSize 和 MaxPermSize 参数则影响非堆内存的大小。正确配置这些选项能有效提升IDE的运行效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

头脑有些不清醒,又没有好好的休息。看了几眼小说,讲到一个人的功成名就,需要很大的毅力。我所需要的毅力就是把无限的生命投入到有意义的事情当中去。


phpstorm在使用时候特别的卡,我找了几点解决方法:

  1. 找到安装目录中的phpstorm64.exe文件,64位系统用这个会好一些
  2. 配置PhpStorm64.exe.vmoptions文件
-Xms128m
-Xmx750m
-XX:MaxPermSize=350m
-XX:ReservedCodeCacheSize=225m
-XX:+UseConcMarkSweepGC
-XX:SoftRefLRUPolicyMSPerMB=50
-ea
-Dsun.io.useCanonCaches=false
-Djava.net.preferIPv4Stack=true
-Xms128m //初始分配的堆内存
-Xmx750m //最大允许分配的堆内存
-XX:MaxPermSize=350m //最大允许分配的非堆内存

其中堆内存和非堆内存的区别为:

Java虚拟机具有一个堆,堆是运行时的数据区域,所有类实例和数组的内存均从此处分配。堆是在Java虚拟机启动时创建的。在JVM中堆之外的内存成为非堆内存(Non-heap memory)

堆内存分配

初始分配的堆内存由-Xms指定,默认是物理内存的1/64;最大分配的堆内存由-Xmx指定,默认是物理内存的1/4。默认空余堆内存小于40%时,Jvm就会增大堆直到-Xmx的最大限制;同理,空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制。因此一般设置-Xms、-Xmx相等以避免每次GC后调整堆的大小。
说明:如果-Xmx不指定或者指定偏小,应用可能会导致java.lang.OutOfMemory错误,此错误来自JVM,不是Throwable的,无法用try……catch捕捉

非堆内存分配

JVM使用-XX:PermSize设置非堆内存初始值,默认是物理内存的1/64;由XX:MaxPermSize设置最大非堆内存的大小,默认是物理内存的1/4。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值