Eclipse解决运行、启动缓慢问题思路

摘要:
最近几天,我的Eclipse运行速度非常慢。具体表现如下:1.只要启动ECLIPSE,硬盘灯就会疯狂闪烁,磁盘会被连续读取;2.已发表的TOMCAT通常为0%;3.偶尔CPU已满;互联网上有无数关于优化的文章,但很少有总是有用的,其中大多数是转载甚至复制的。如图所示:5.清理项目文件,删除。元数据。plugingsorg。日食应用程序。usagedata应保留录制目录中的所有文件。完成以上操作后,我的Eclipse可以更快地启动、发布或编译,尤其是在启动时。

我的Eclipse近几天运行时速度奇慢,具体表现为:

1、只要ECLIPSE启动后,硬盘灯就狂闪,不停的读盘;

2、发布TOMCAT经常在0%;

3、偶尔CPU占满;

网上讲优化的文章无数,但是总是有用的却很少,大部分是转载甚至是抄袭的。在借鉴各个文章的做法并不断尝试后,我的问题终于解决了。

1、启动参数的优化;

我的启动参数为:

-Xms976m -Xmx976m -XX:PermSize=128m -XX:MaxPermSize=128m -Xmn168m -XX:+DisableExplicitGC

其中XX:PermSize和XX:MaxPermSize是必须的,仅仅设置Xmx,经常出现ECLIPSE内存溢出的情况;

减少jvm内存回收引起的eclipse卡的问题 :
这个主要是jvm在client模式,进行内存回收时,会停下所有的其它工作,带回收完毕才去执行其它任务,在这期间eclipse就卡住了。所以适当的增加jvm申请的内存大小来减少其回收的次数甚至不回收,就会是卡的现象有明显改善。 
主要通过以下的几个jvm参数来设置堆内存的: 

-Xmx512m最大总堆内存,一般设置为物理内存的1/4
-Xms512m初始总堆内存,一般将它设置的和最大堆内存一样大,这样就不需要根据当前堆使用情况而调整堆的大小了
-Xmn192m年轻带堆内存,sun官方推荐为整个堆的3/8
堆内存的组成总堆内存 = 年轻带堆内存 + 年老带堆内存 + 持久带堆内存
年轻带堆内存对象刚创建出来时放在这里
年老带堆内存对象在被真正会回收之前会先放在这里
持久带堆内存class文件,元数据等放在这里
-XX:PermSize=128m持久带堆的初始大小
-XX:MaxPermSize=128m持久带堆的最大大小,eclipse默认为256m。如果要编译jdk这种,一定要把这个设的很大,因为它的类太多了。
比如,下图(这个的内存为4G):

Eclipse解决运行、启动缓慢问题思路第1张

2、启动插件优化:

windows - preference- general - startup and shutdown 里,只保留第1、3、4,其他全部取消,保留的为:

Usage DAta Gathering Plug-in。

Equinox Provisioning Platform Automatic Updata Support。

WTP Webservice UI Plug-in。

如图:

Eclipse解决运行、启动缓慢问题思路第2张

4、关闭验证

windows - preference-Validation 全部取消,只保留Manual 列;

在工程上右键-Validation ,同样全部取消,只保留Manual列,如果需要检查代码是否有错,可以在代码文件上右键,手动验证。

如图:

Eclipse解决运行、启动缓慢问题思路第3张

5、清理工程文件

删除工作空间目录下.metadata.pluginsorg.eclipse.epp.usagedata.recording目录里的所有文件,主要要保留这个目录,只删除目录下文件即可

在经过以上操作后,我的Eclipse无论是启动还是发布或者是编译工程,速度都提升了不少,特别是启动。而且运行起来相对很流畅,闪退、假死和吃内存等一系列问题得到基本解决。

以上仅供参考大家参考,欢迎反馈问题和建议,谢谢。

更多深度优化请参考:http://chaoxz2005.blog.163.com/blog/static/15036542013411105519685/

免责声明:文章转载自《Eclipse解决运行、启动缓慢问题思路》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇cap文件格式解析关于微擎小程序的操作的步骤,如何上传小程序?下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

npm run serve报错提示js堆内存不足

问题:执行npm run serve时报错,提示js堆内存不足 报错:FATAL ERROR: Ineffective mark-compacts near heap limit Allocation failed - JavaScript heap out of memory 在网上找的可以扩展内存的方法: 1、在添加package.json中添加语句:...

判断栈和堆的生长方向

如何判断栈的增长方向? 对于一个用惯了i386系列机器的人来说,这似乎是一个无聊的问题,因为栈就是从高地址向低地址增长。不过,显然这不是这个问题的目的,既然把这个问题拿出来,问的就不只是i386系列的机器,跨硬件平台是这个问题的首先要考虑到的因素。 在一个物质极大丰富的年代,除非无路可退,否则我们坚决不会使用汇编去解决问题,而对于这种有系统编程味道的问题,...

Elasticsearch 堆内存

1、什么是堆内存? Java 中的堆是 JVM 所管理的最大的一块内存空间,主要用于存放各种类的实例对象。 在 Java 中,堆被划分成两个不同的区域: 新生代 ( Young )、 老年代 ( Old )。 新生代 ( Young ) 又被划分为三个区域 Eden、 From Survivor、 To Survivor。 这样划分的目的是为了使...

Java 堆内存 新生代 (转)

Java 中的堆是 JVM 所管理的最大的一块内存空间,主要用于存放各种类的实例对象。在 Java 中,堆被划分成两个不同的区域:新生代 ( Young )、老年代 ( Old )。新生代 ( Young ) 又被划分为三个区域:Eden、From Survivor、To Survivor。这样划分的目的是为了使 JVM 能够更好的管理堆内存中的对象,包括...

【javascript】浅析js中的堆和栈

这里先说两个概念:1、堆(heap)2、栈(stack)堆 是堆内存的简称。栈 是栈内存的简称。说到堆栈,我们讲的就是内存的使用和分配了,没有寄存器的事,也没有硬盘的事。各种语言在处理堆栈的原理上都大同小异。堆是动态分配内存,内存大小不一,也不会自动释放。栈是自动分配相对固定大小的内存空间,并由系统自动释放。 javascript的基本类型就5种:Unde...

jvm参数优化

一、HotSpot JVM 提供了三类参数 现在的JVM运行Java程序(和其它的兼容性语言)时在高效性和稳定性方面做的非常出色。例如:自适应内存管理、垃圾收集、及时编译、动态类加载、锁优化等。虽然有了这种程度的自动化(或者说有这么多自动化),但是JVM仍然提供了足够多的外部监控和手动调优工具(允许命令行参数可以在JVM启动时传入到JVM中)。在有错误或低...