前情提要
今早启动idea的时候,突然启动不了,并且编译的时候报错。查看报错代码又不是项目本身的代码,是jetbrains的报错,很费解。百度了很多文档没有解决方案,去stackoverflow查了一下,才得以解决,所以分享一下自己的解决办法。(stackoverflow大法好)
报错代码
Error:Internal error: (java.lang.NegativeArraySizeException) null
java.lang.NegativeArraySizeException
at com.intellij.util.io.IOUtil.readString(IOUtil.java:48)
at org.jetbrains.jps.incremental.storage.BuildTargetTypeState.load(BuildTargetTypeState.java:68)
at org.jetbrains.jps.incremental.storage.BuildTargetTypeState.<init>(BuildTargetTypeState.java:55)
at org.jetbrains.jps.incremental.storage.BuildTargetsState.getTypeState(BuildTargetsState.java:114)
at org.jetbrains.jps.incremental.storage.BuildTargetsState.getAverageBuildTime(BuildTargetsState.java:108)
at org.jetbrains.jps.incremental.messages.BuildProgress.<init>(BuildProgress.java:70)
at org.jetbrains.jps.incremental.IncProjectBuilder.runBuild(IncProjectBuilder.java:364)
at org.jetbrains.jps.incremental.IncProjectBuilder.build(IncProjectBuilder.java:178)
at org.jetbrains.jps.cmdline.BuildRunner.runBuild(BuildRunner.java:138)
at org.jetbrains.jps.cmdline.BuildSession.runBuild(BuildSession.java:302)
at org.jetbrains.jps.cmdline.BuildSession.run(BuildSession.java:135)
at org.jetbrains.jps.cmdline.BuildMain$MyMessageHandler.lambda$channelRead0$0(BuildMain.java:229)
at org.jetbrains.jps.service.impl.SharedThreadPoolImpl.lambda$executeOnPooledThread$0(SharedThreadPoolImpl.java:42)
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511)
at java.util.concurrent.FutureTask.run(FutureTask.java:266)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
at java.lang.Thread.run(Thread.java:745)
解决方案
1.自动清除idea缓存
点击idea的file,找到如图红框内容
重启之后,idea会重新创建缓存和索引,如果成功,就不用执行下面的步骤了。
2.手动删除idea缓存
在C:\Users\你当前使用的用户\idea的对应文件,我的是2018.3,则为.IntelliJIdea2018.3\system找到如下文件,删除掉这个caches文件夹即可。
重启idea,会重新创建缓存和索引,如果成功,同上,就不用继续操作了。
3.删除项目相关的配置文档
在2中的文件夹中,进入compile-server文件夹中,删除掉对应的项目的文件夹,比如项目test,则会看到文件夹中有test_*******的文件夹,删除掉即可。
重启idea,基本上就能正常使用了。