로그인

검색

OBG
조회 수 62 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 게시글 수정 내역 댓글로 가기 인쇄

https://v8.dev/blog/json-stringify

 

ChatGPT 요약

주요 최적화 전략

1. Side‑Effect‑Free Fast Path (사이드 이펙트 없는 고속 경로)

  • JSON.stringify 실행 중 부수 효과(side effects) — 예를 들어 사용자 정의 코드 실행이나 가비지 컬렉션을 유발하는 내부 작업 — 가 없다고 판단되는 경우, 훨씬 빠른 전용 경로를 사용합니다.

  • 이 경로는 반복적(iterative) 구조로 구현되어 있기에, 재귀 사용 시 필요한 스택 오버플로우 검사 등을 줄일 수 있고, 깊은 중첩 객체도 안전하게 직렬화할 수 있습니다.

2. 문자열 표현별 특화 구현

  • V8 내부에서는 문자열이 ASCII만 포함된 경우 1바이트, 한 글자만 비-ASCII여도 전체가 2바이트로 메모리 이용됩니다.

  • 이를 고려해 1바이트 전용 문자열 처리기2바이트 전용 처리기를 각각 컴파일해 두었고, 적절한 시점에 효율적으로 전환할 수 있도록 구성했습니다.

3. SIMD 기반 문자열 이스케이프 검사

  • JSON 직렬화 시 자주 등장하는 이스케이프 대상 문자(", \ 등)를 찾기 위해:

    • 긴 문자열: SIMD 하드웨어 명령어(예: ARM64 Neon)를 활용해 여러 문자를 한 번에 검사

    • 짧은 문자열: SWAR 방식(SIMD Within A Register)으로 일반 레지스터에서 비트 조작으로 병렬 검사 수행

  • 이 방식 덕분에 특수 문자가 없다면—종종 있는 경우—문자열 전체를 단순히 복사만 해도 되므로 매우 빠릅니다.

4. Express Lane (익스프레스 레인)

  • 고속 경로 내부에서도, 일반적인 속성 순회 절차를 또 일부 간소화하는 **더 빠른 “익스프레스 레인”**이 따로 구성되어 있습니다.

  • 기본은 키가 문자열이어야 하고 심벌(Symbol)이 아닌 등 일반적인 조건에 부합할 때 적용됩니다.


제한 사항

  • replacerspace 옵션 사용 시에는 고속 경로를 이용할 수 없고, 느린 일반 경로로 처리됩니다.

  • 객체나 배열에 커스텀 .toJSON() 메서드가 있거나, 숫자 인덱스형 속성이 존재하는 등의 경우에도 일반 경로로 처리됩니다.

  • 문자열 타입이 복잡한 내부 표현(예: ConsString)을 사용하는 경우도 일반 경로로 넘어갑니다.


요약

V8는 JSON.stringify평균적으로 두 배 이상 빠르게 만들기 위해, 부수 효과 없는 경우에만 작동하는 고속 경로, 문자열 데이터 타입에 맞춘 특화 구현, 그리고 SIMD 기반 처리 등의 최적화 전략을 도입했습니다. 이로 인해 직렬화 성능이 크게 향상되었고, 특히 일반적인 단순 데이터 객체의 경우 훨씬 더 빠르게 직렬화할 수 있게 되었습니다.

 

1차 출처: https://news.ycombinator.com/item?id=44786005

2차 출처: https://news.hada.io/topic?id=22356

 

?

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
공지 Tool/etc Programming 게시판 관련 2 MoA 2014.11.01 15548
306 API/MFC __cdecl , __pascal, __stdcall MoA 2013.07.28 3500
305 C/C++ __FILE__ __LINE__ __FUNCTION__ 등 매크로 MoA 2014.01.02 3820
304 LLM [12월 1주] 떠오르는 '미스트랄 7B'...'라마 2' 이어 한국어 모델 세대교체 주도 OBG 2024.03.05 2355
303 Python [GUI] Tkinter, wxPython MoA 2013.11.27 3090
302 Python [GUI] wxPython 기본 프로그램 file MoA 2013.11.30 3488
301 Python [GUI] wxPython에서 에러메시지 콘솔로 보는 법 MoA 2013.12.03 3852
300 Deeplearning [ifkakao] 추천 시스템: 맥락과 취향 사이 줄타 OBG 2024.01.10 2330
299 Web [Javascript] 비동기, Promise, async, await 확실하게 이해하기 OBG 2022.05.27 2579
298 Library [OpenCV] 얼굴 인식 예제 file MoA 2012.10.14 3929
297 Tool/etc [S/W 공학] 월-인원(man-month), LOC MoA 2013.09.23 3235
296 LLM [VESSL AI] 뉴욕주민의 프로젝트플루토 — LLM, LLMOps를 활용한 금융 미디어의 혁신 OBG 2024.04.21 2634
295 Python [게임 만들기] 강좌 진행 예정 2 MoA 2014.04.26 3968
294 Python [농장게임 만들기] 1. Nubcake Farms 게임 소개 4 file OBG 2014.04.26 4301
293 Python [농장게임 만들기] 10. 상점을 추가하자 file MoA 2014.05.01 4466
292 Python [농장게임 만들기] 2. Nubcake Farms 클래스 분석 3 file OBG 2014.04.26 3443
291 Python [농장게임 만들기] 3. 배경을 그리자 6 file MoA 2014.04.28 4381
290 Python [농장게임 만들기] 4. 펜스를 그리자 5 file MoA 2014.04.30 3346
289 Python [농장게임 만들기] 5. 플레이어를 추가하자 1 file MoA 2014.04.30 3302
288 Python [농장게임 만들기] 6. 나머지 오브젝트를 그리자 1 file MoA 2014.05.01 3882
287 Python [농장게임 만들기] 7. 농부 행동 추가 1 file MoA 2014.05.01 3700
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 16 Next
/ 16