>백엔드 개발 >파이썬 튜토리얼 >Python 3.6 사전 구현은 어떻게 메모리 사용량을 개선하고 삽입 순서를 유지합니까?

Python 3.6 사전 구현은 어떻게 메모리 사용량을 개선하고 삽입 순서를 유지합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-02 18:04:39658검색

How Does Python 3.6  Dictionary Implementation Improve Memory Usage and Preserve Insertion Order?

Python 3.6: 사전이 삽입 순서를 유지합니다

Python 3.6부터 CPython 구현의 사전은 이전 버전과 크게 다른 삽입 순서를 나타냅니다. . 이 기능은 이제 Python 3.7에서 보장된 언어 기능입니다.

향상된 메모리 사용량 및 성능

새로운 사전 구현은 이전 버전에 비해 메모리 사용량을 20-25% 크게 줄입니다. 파이썬 3.5. 이러한 개선은 구현 시 별도의 배열 사용에서 비롯됩니다:

  • dk_entries: 항목(PyDictKeyEntry)을 삽입 순서로 저장합니다.
  • dk_indices: 해시 역할을 하는 dk_entries의 항목에 대한 색인을 저장합니다.

이전에는 PyDictKeyEntry 유형의 희소 배열을 할당해야 했고, 이로 인해 성능 고려 사항으로 인해 공간이 낭비되었습니다. 새로운 접근 방식은 필요한 항목만 할당하고 메모리를 덜 소비하는 intX_t 유형의 희소 배열을 사용합니다.

사용된 데이터 구조

원래 사전은 [ keyhash, key, value] '-'로 표시된 빈 항목이 있는 희소 배열입니다. 새로운 접근 방식은 데이터를 다음과 같이 구성합니다.

  • 색인: [없음, 1, 없음, 없음, 없음, 0, 없음, 2]
  • 항목: [[-9092791511155847987, 'timmy', 'red'],

            [-8522787127447073495, 'barry', 'green'],
            [-6480567542315338377, 'guido', 'blue']]
    

이 수정된 구조는 메모리 오버헤드를 크게 줄입니다.

삽입의 이점 정렬

새로운 사전 구현은 주로 메모리 최적화에 중점을 두고 있지만 삽입 순서 지정 기능은 다음과 같은 편리한 응용 프로그램을 제공합니다.

  • 사전.
  • 사전 표시 또는 반복 순서 사용자 정의

다양한 Python 구현이나 향후 언어 버전에서는 삽입 순서가 보장되지 않는다는 점에 유의하는 것이 중요합니다. 그러나 Python 3.7 이상에서는 신뢰할 수 있는 기능이 보장됩니다.

위 내용은 Python 3.6 사전 구현은 어떻게 메모리 사용량을 개선하고 삽입 순서를 유지합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.