Python의 슬롯 속성은 클래스 수준에서 데이터 속성 (인스턴스 변수)을 명시 적으로 선언하는 데 사용되는 도구이며, 이는보다 효율적인 메모리 사용량과 더 빠른 속성 액세스로 이어질 수 있습니다. 클래스가 __slots__
속성을 정의하면 Python은 동적 사전을 사용하여 인스턴스 속성을 저장하는 대신 클래스의 각 인스턴스에 대해 작은 고정 크기 배열을 만듭니다. 이 메커니즘은 몇 가지 목적을 제공합니다.
__slots__
사용하면 인스턴스의 __dict__
생성되지 않으므로 특히 많은 인스턴스를 처리 할 때 메모리를 저장합니다.__slots__
가능 클래스에서 속성에 액세스하는 것은 사전 조회의 오버 헤드를 피하기 때문에 표준 사전 기반 인스턴스의 속성에 액세스하는 것보다 빠를 수 있습니다.__slots__
정의 될 때, Python은 __slots__
에 __dict__
에 명시 적으로 포함되지 않는 한, __slots__
에 정의 된 것들에 대한 새로운 속성의 생성을 제한합니다. 다음은 __slots__
사용하는 방법의 기본 예입니다.
<code class="python">class Point: __slots__ = ('x', 'y') def __init__(self, x, y): self.x = x self.y = y</code>
__slots__
의 사용은 몇 가지 성능 이점을 제공 할 수 있습니다.
__slots__
는 인스턴스의 __dict__
고정 크기 배열로 대체하므로 인스턴스의 메모리 풋 프린트를 크게 줄일 수 있습니다. 이것은 많은 인스턴스를 만들 때 특히 유익합니다.__slots__
에 정의 된 속성은 사전에 저장된 것보다 더 빨리 액세스 할 수 있습니다. 작은 고정 크기 배열에서 요소에 액세스하는 것이 일반적으로 사전 조회를 수행하는 것보다 빠르기 때문입니다.__slots__
사용하는 인스턴스는 따라야 할 참조가 적기 때문에 쓰레기 수집기에 의해 더 빨리 수집 될 수 있습니다.이러한 이점을 설명하려면 다음 예를 고려하십시오.
<code class="python">import sys class StandardPoint: def __init__(self, x, y): self.x = x self.y = y class SlotPoint: __slots__ = ('x', 'y') def __init__(self, x, y): self.x = x self.y = y standard = StandardPoint(1, 2) slot = SlotPoint(1, 2) print(sys.getsizeof(standard)) # Output may be around 56 bytes print(sys.getsizeof(slot)) # Output may be around 32 bytes</code>
이 예에서 SlotPoint
인스턴스는 StandardPoint
인스턴스보다 메모리가 적습니다.
__slots__
사용은 다음과 같은 방식으로 속성 할당에 영향을 미칩니다.
__slots__
정의되면 __slots__
에 나열된 속성 만 인스턴스에 할당 할 수 있습니다. __slots__
에 __slots__
에 포함되지 않으면 __dict__
에없는 속성을 할당하면 AttributeError
발생합니다.__dict__
: 기본적으로 __slots__
가있는 클래스의 인스턴스에는 __dict__
가 없습니다. 이는 __dict__
__slots__
에 명시 적으로 포함되지 않는 한 동적 속성 할당이 비활성화된다는 것을 의미합니다.__weakref__
: 클래스가 약한 참조를 지원 해야하는 경우 __weakref__
__slots__
에 포함되어야합니다.다음은 이러한 효과를 보여주는 예입니다.
<code class="python">class RestrictedPoint: __slots__ = ('x', 'y') point = RestrictedPoint() point.x = 10 # This is allowed point.y = 20 # This is allowed try: point.z = 30 # This will raise an AttributeError except AttributeError as e: print(e) # Output: 'RestrictedPoint' object has no attribute 'z'</code>
예, __slots__
상속 재산과 함께 사용할 수 있지만 명심해야 할 몇 가지 고려 사항이 있습니다.
__slots__
정의하면 슈퍼 클래스에서 슬롯을 상속하지만 슈퍼 클래스가 __slots__
정의하는 경우에만 가능합니다. 슈퍼 클래스가 __slots__
사용하지 않으면 인스턴스는 여전히 __dict__
사용하여 메모리 비 효율성으로 이어질 수 있습니다.__dict__
결합 : 서브 클래스가 동적 속성을 허용하려면 __slots__
에 __dict__
포함 할 수 있습니다. 그러나 이것은 처음에 __slots__
사용하는 메모리 절약 목적을 물리 칠 수 있습니다.__slots__
와 함께 다중 상속을 사용할 때 모든 클래스는 __slots__
정의하거나 __slots__
정의하는 클래스에서 상속해야합니다. 한 부모 클래스가 __slots__
사용하지 않으면 서브 클래스의 인스턴스에는 여전히 __dict__
가 있습니다.다음은 다음과 같은 고려 사항을 설명하기위한 예입니다.
<code class="python">class Base: __slots__ = ('x',) class Derived(Base): __slots__ = ('y',) # Inherits 'x' from Base derived = Derived() derived.x = 10 # Inherited from Base derived.y = 20 # Defined in Derived class FlexibleDerived(Base): __slots__ = ('y', '__dict__') # Allows dynamic attributes flexible = FlexibleDerived() flexible.x = 10 # Inherited from Base flexible.y = 20 # Defined in FlexibleDerived flexible.z = 30 # Dynamic attribute, allowed because of __dict__</code>
결론적으로, __slots__
상속과 함께 효과적으로 사용될 수 있지만, 클래스 계층에서 원하는 메모리 최적화 및 속성 동작이 달성되도록 신중한 계획이 필요합니다.
위 내용은 __slots__ 속성의 목적을 설명하십시오.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!