Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/json/13.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/loops/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 需要解析一个大的json文件_Java_Json - Fatal编程技术网

Java 需要解析一个大的json文件

Java 需要解析一个大的json文件,java,json,Java,Json,目前我正在进入“java.lang.OutOfMemoryError:java堆空间” 下面是编写的代码,我在这里传递输入流以获取 JsonReader对象继续。请让我知道该怎么做 最佳方法。提前谢谢 JsonReader reader = new JsonReader(new InputStreamReader(inputStream)); JsonObject element = new JsonParser().parse(reader).getAsJsonObject(); /

目前我正在进入“java.lang.OutOfMemoryError:java堆空间” 下面是编写的代码,我在这里传递输入流以获取
JsonReader对象继续。请让我知道该怎么做
最佳方法。提前谢谢

JsonReader reader = new JsonReader(new InputStreamReader(inputStream));
    JsonObject element = new JsonParser().parse(reader).getAsJsonObject();
//堆栈跟踪

com.domo.connector.util.MagicException: Failed parsing JSON source: JsonReader at line 1 column 80720228 to Json
    at com.domo.connector.adaptv.api.Client.get(Client.java:125)
    at com.domo.connector.adaptv.api.Client.get(Client.java:86)
    at com.domo.connector.adaptv.api.AdhocReportClient.getFirstPage(AdhocReportClient.java:24)
    at com.domo.connector.adaptv.ProcessRecords.getClientWithFirstPageOfData(ProcessRecords.java:116)
    at com.domo.connector.adaptv.ProcessRecords.readData(ProcessRecords.java:58)
    at com.domo.connector.adaptv.ProcessRecordsFunctionalTest.testCustomer(ProcessRecordsFunctionalTest.java:38)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:601)
    at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:84)
    at org.testng.internal.Invoker.invokeMethod(Invoker.java:714)
    at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901)
    at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231)
    at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)
    at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)
    at org.testng.TestRunner.privateRun(TestRunner.java:767)
    at org.testng.TestRunner.run(TestRunner.java:617)
    at org.testng.SuiteRunner.runTest(SuiteRunner.java:334)
    at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:329)
    at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)
    at org.testng.SuiteRunner.run(SuiteRunner.java:240)
    at org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
    at org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
    at org.testng.TestNG.runSuitesSequentially(TestNG.java:1224)
    at org.testng.TestNG.runSuitesLocally(TestNG.java:1149)
    at org.testng.TestNG.run(TestNG.java:1057)
    at org.testng.remote.RemoteTestNG.run(RemoteTestNG.java:111)
    at org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:204)
    at org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:175)
Caused by: com.google.gson.JsonParseException: Failed parsing JSON source: JsonReader at line 1 column 80720228 to Json
    at com.google.gson.JsonParser.parse(JsonParser.java:88)
    at com.domo.connector.adaptv.parser.AdapTVParser.parse(AdapTVParser.java:45)
    at com.domo.connector.adaptv.api.Client.get(Client.java:102)
    ... 29 more
Caused by: java.lang.OutOfMemoryError: Java heap space
    at java.util.ArrayList.<init>(ArrayList.java:132)
    at java.util.ArrayList.<init>(ArrayList.java:139)
    at com.google.gson.JsonArray.<init>(JsonArray.java:40)
    at com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:656)
    at com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:667)
    at com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:659)
    at com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:667)
    at com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:642)
    at com.google.gson.internal.Streams.parse(Streams.java:44)
    at com.google.gson.JsonParser.parse(JsonParser.java:84)
    at com.domo.connector.adaptv.parser.AdapTVParser.parse(AdapTVParser.java:45)
    at com.domo.connector.adaptv.api.Client.get(Client.java:102)
    at com.domo.connector.adaptv.api.Client.get(Client.java:86)
    at com.domo.connector.adaptv.api.AdhocReportClient.getFirstPage(AdhocReportClient.java:24)
    at com.domo.connector.adaptv.ProcessRecords.getClientWithFirstPageOfData(ProcessRecords.java:116)
    at com.domo.connector.adaptv.ProcessRecords.readData(ProcessRecords.java:58)
    at com.domo.connector.adaptv.ProcessRecordsFunctionalTest.testCustomer(ProcessRecordsFunctionalTest.java:38)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:601)
    at org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:84)
    at org.testng.internal.Invoker.invokeMethod(Invoker.java:714)
    at org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901)
    at org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231)
    at org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)
    at org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)
    at org.testng.TestRunner.privateRun(TestRunner.java:767)
    at org.testng.TestRunner.run(TestRunner.java:617)
    at org.testng.SuiteRunner.runTest(SuiteRunner.java:334)
    at org.testng.SuiteRunner.runSequentially(SuiteRunner.java:329)
    at org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)
com.domo.connector.util.magiceException:无法将第1行第80720228列的JSON源代码:JsonReader解析为JSON
位于com.domo.connector.adaptev.api.Client.get(Client.java:125)
位于com.domo.connector.adaptev.api.Client.get(Client.java:86)
位于com.domo.connector.adaptev.api.AdhocReportClient.getFirstPage(AdhocReportClient.java:24)
在com.domo.connector.adaptev.ProcessRecords.getClientWithFirstPageOfData(ProcessRecords.java:116)上
在com.domo.connector.adaptev.ProcessRecords.readData(ProcessRecords.java:58)上
在com.domo.connector.adaptev.ProcessRecordsFunctionalTest.testCustomer(ProcessRecordsFunctionalTest.java:38)
在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处
在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)中
在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中
位于java.lang.reflect.Method.invoke(Method.java:601)
位于org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:84)
位于org.testng.internal.Invoker.invokeMethod(Invoker.java:714)
位于org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901)
位于org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231)
位于org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)
位于org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)
位于org.testng.TestRunner.privateRun(TestRunner.java:767)
位于org.testng.TestRunner.run(TestRunner.java:617)
位于org.testng.SuiteRunner.runTest(SuiteRunner.java:334)
在org.testng.SuiteRunner.runSequential上(SuiteRunner.java:329)
位于org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)
运行(SuiteRunner.java:240)
位于org.testng.SuiteRunnerWorker.runSuite(SuiteRunnerWorker.java:52)
位于org.testng.SuiteRunnerWorker.run(SuiteRunnerWorker.java:86)
在org.testng.testng.runSuitesSequentially上(testng.java:1224)
位于org.testng.testng.runSuitesLocally(testng.java:1149)
位于org.testng.testng.run(testng.java:1057)
位于org.testng.remote.RemoteTestNG.run(RemoteTestNG.java:111)
位于org.testng.remote.RemoteTestNG.initAndRun(RemoteTestNG.java:204)
位于org.testng.remote.RemoteTestNG.main(RemoteTestNG.java:175)
原因:com.google.gson.JsonParseException:无法将第1行第80720228列的JSON源代码:JsonReader解析为JSON
位于com.google.gson.JsonParser.parse(JsonParser.java:88)
位于com.domo.connector.adaptev.parser.adaptevparser.parse(adaptevparser.java:45)
位于com.domo.connector.adaptev.api.Client.get(Client.java:102)
... 还有29个
原因:java.lang.OutOfMemoryError:java堆空间
位于java.util.ArrayList。(ArrayList.java:132)
位于java.util.ArrayList。(ArrayList.java:139)
位于com.google.gson.JsonArray(JsonArray.java:40)
位于com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:656)
位于com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:667)
位于com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:659)
位于com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:667)
位于com.google.gson.internal.bind.TypeAdapters$25.read(TypeAdapters.java:642)
位于com.google.gson.internal.Streams.parse(Streams.java:44)
位于com.google.gson.JsonParser.parse(JsonParser.java:84)
位于com.domo.connector.adaptev.parser.adaptevparser.parse(adaptevparser.java:45)
位于com.domo.connector.adaptev.api.Client.get(Client.java:102)
位于com.domo.connector.adaptev.api.Client.get(Client.java:86)
位于com.domo.connector.adaptev.api.AdhocReportClient.getFirstPage(AdhocReportClient.java:24)
在com.domo.connector.adaptev.ProcessRecords.getClientWithFirstPageOfData(ProcessRecords.java:116)上
在com.domo.connector.adaptev.ProcessRecords.readData(ProcessRecords.java:58)上
在com.domo.connector.adaptev.ProcessRecordsFunctionalTest.testCustomer(ProcessRecordsFunctionalTest.java:38)
在sun.reflect.NativeMethodAccessorImpl.invoke0(本机方法)处
在sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)中
在sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)中
位于java.lang.reflect.Method.invoke(Method.java:601)
位于org.testng.internal.MethodInvocationHelper.invokeMethod(MethodInvocationHelper.java:84)
位于org.testng.internal.Invoker.invokeMethod(Invoker.java:714)
位于org.testng.internal.Invoker.invokeTestMethod(Invoker.java:901)
位于org.testng.internal.Invoker.invokeTestMethods(Invoker.java:1231)
位于org.testng.internal.TestMethodWorker.invokeTestMethods(TestMethodWorker.java:127)
位于org.testng.internal.TestMethodWorker.run(TestMethodWorker.java:111)
位于org.testng.TestRunner.privateRun(TestRunner.java:767)
位于org.testng.TestRunner.run(TestRunner.java:617)
位于org.testng.SuiteRunner.runTest(SuiteRunner.java:334)
在org.testng.SuiteRunner.runSequential上(SuiteRunner.java:329)
位于org.testng.SuiteRunner.privateRun(SuiteRunner.java:291)

如果文档很大,则无法在内存中构建DOM树/JSON对象。您必须使用pull或SAX解析器并逐步计算文档。这将迫使您重写处理JSON对象的代码

看到或


如果您正在解析某种类型的流,基于事件的方法会更好,如果它只是一个文件,一个拉式解析器就足够了。

希望这就是您想要的json文件的大小有多大?