상당히 큰 크기의 JSON 파일을 처리할 때 표준 JsonConvert.Deserialize 메서드를 사용하면 문제가 발생하는 경우가 많습니다. 이 문서에서는 Json.NET에서 제공하는 고유한 솔루션을 자세히 살펴봄으로써 이 문제를 해결할 것입니다.
원래 질문에서 설명한 것처럼 기본 역직렬화 방법을 사용하면 처리 시 메모리 예외가 발생할 수 있습니다. 대용량 JSON 파일. 이는 대개 역직렬화 프로세스의 인메모리 특성으로 인해 발생하며, 이는 대규모 데이터 세트에 문제가 될 수 있습니다.
질문에 설명된 특정 시나리오에서는 추가 합병증이 발생합니다. JSON 파일에는 잘못된 구문으로 구분된 여러 배열이 포함되어 있어 JSON 표준을 준수하지 않습니다. 이 잘못된 형식은 Json.NET의 자동 역직렬화에 문제를 일으켰습니다.
이러한 문제를 극복하기 위해 Json.NET은 JsonTextReader라는 특수 솔루션을 제공합니다. JsonTextReader를 직접 사용하여 JSON 파일을 읽으면 SupportMultipleContent 플래그를 true로 설정할 수 있습니다. 이 플래그를 사용하면 리더가 여러 배열이 포함된 비표준 JSON 형식을 처리할 수 있습니다.
전체 파일을 한 번에 역직렬화하는 대신 스트리밍 접근 방식을 채택합니다. 루프를 사용하면 JSON 파일 내의 각 개별 항목을 역직렬화하여 메모리 효율적인 방식으로 데이터를 처리할 수 있습니다.
아래 코드 조각은 이러한 스트리밍 접근 방식을 보여줍니다.
using (WebClient client = new WebClient()) using (Stream stream = client.OpenRead(stringUrl)) using (StreamReader streamReader = new StreamReader(stream)) using (JsonTextReader reader = new JsonTextReader(streamReader)) { reader.SupportMultipleContent = true; var serializer = new JsonSerializer(); while (reader.Read()) { if (reader.TokenType == JsonToken.StartObject) { Contact c = serializer.Deserialize<Contact>(reader); Console.WriteLine(c.FirstName + " " + c.LastName); } } }
JsonTextReader를 SupportMultipleContent 플래그를 설정하면 비표준 구문이 발생하는 경우에도 큰 JSON 파일을 효과적으로 구문 분석할 수 있습니다. 이 접근 방식은 메모리 효율성과 데이터 무결성을 모두 보장합니다.
위 내용은 .NET에서 대용량 비표준 JSON 파일을 효율적으로 구문 분석하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!