>백엔드 개발 >파이썬 튜토리얼 >Python 목록 조각화는 복사본이나 참조를 생성합니까?

Python 목록 조각화는 복사본이나 참조를 생성합니까?

DDD
DDD원래의
2024-11-08 14:32:02924검색

Does Python List Slicing Create Copies or References?

Python에서 복사하지 않고 부분 목록 분할

Python의 목록 분할 작업은 복사본을 만드는 대신 원본 목록의 요소에 대한 참조를 생성합니다. 이 동작은 슬라이싱이 목록 내 요소의 개체 ID를 유지한다는 사실에서 비롯됩니다.

데모

이를 설명하려면 다음 목록을 고려하세요.

<code class="python">L = [1000 + 1, 1000 + 1, 1000 + 1]</code>

이러한 정수는 동일한 값을 가지더라도 서로 다릅니다. 객체:

<code class="python">map(id, L)
[140502922988976, 140502922988952, 140502922988928]</code>

목록을 슬라이싱하면 참조만 복사됩니다.

<code class="python">b = L[1:3]
map(id, b)
[140502922988952, 140502922988928]</code>

슬라이싱의 메모리 오버헤드

슬라이싱은 생성되지 않습니다. 객체의 사본에는 참조 복사가 포함됩니다. 이러한 참조는 목록과 관련된 전체 메모리 오버헤드에 추가됩니다.

<code class="python">for i in range(len(L)):
    x = L[:i]
    print('len: {}'.format(len(x)))
    print('size: {}'.format(sys.getsizeof(x)))</code>

이 오버헤드는 특히 큰 목록이나 사전과 같이 메모리 집약적인 개체로 작업할 때 누적될 수 있습니다.

대안 : 뷰

Python에는 목록의 뷰나 별칭을 생성하는 쉬운 방법이 없습니다. 그러나 NumPy 배열은 이 기능을 제공합니다. NumPy 배열을 분할하면 원래 배열과 메모리를 공유하는 뷰가 생성됩니다. 이렇게 하면 상당한 메모리를 절약할 수 있지만 개체를 ​​수정할 때 잠재적인 위험이 발생할 수 있습니다.

위 내용은 Python 목록 조각화는 복사본이나 참조를 생성합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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