idea启动时Error:Internal error: (java.lang.NegativeArraySizeException) null报错

前情提要

今早启动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启动时Error:Internal error: (java.lang.NegativeArraySizeException) null报错_第1张图片
idea启动时Error:Internal error: (java.lang.NegativeArraySizeException) null报错_第2张图片
重启之后,idea会重新创建缓存和索引,如果成功,就不用执行下面的步骤了。

2.手动删除idea缓存

在C:\Users\你当前使用的用户\idea的对应文件,我的是2018.3,则为.IntelliJIdea2018.3\system找到如下文件,删除掉这个caches文件夹即可。
在这里插入图片描述
重启idea,会重新创建缓存和索引,如果成功,同上,就不用继续操作了。

3.删除项目相关的配置文档

在2中的文件夹中,进入compile-server文件夹中,删除掉对应的项目的文件夹,比如项目test,则会看到文件夹中有test_*******的文件夹,删除掉即可。
idea启动时Error:Internal error: (java.lang.NegativeArraySizeException) null报错_第3张图片
重启idea,基本上就能正常使用了。

你可能感兴趣的:(心得感悟)