사진과 음악을 좋아하는 개발자 지망생의 블로그

메모리 구조와 python memory management 본문

CS/자료구조 & 알고리즘

메모리 구조와 python memory management

devculture309 2023. 7. 11. 14:51
반응형

1. 메모리 구조

메모리 구조에는 크게 code, data, stack, heap이 있다
code에는 실행할 프로그램의 코드가
data에는 전역변수와 정적 변수가
stack에는 함수의 매개변수와 지역변수가
heap에는 동적으로 할당하는 변수나 메소드가 저장된다
data를 조금 더 분해하면 초기화된 영역과 초기화되지 않은 영역(BSS)이 있다

 

 

2.  Python Memory Management

파이썬은 python memory management 에 의해 관리되고 있다

파이썬에서 변수가 선언되면 변수에 값이 들어가는 것이 아니라
python memory management에 의해 heap영역에서 선언된 변수에 메모리 영역을 할당해 주고
변수에는 할당된 변수의 '주소'가 저장된다. 그리고 주소에 해당된 메모리에 변수에 담은 값이 저장된다.
예를들어, a = 10

a = 1

 이라는 명령어를 실행하면
python memory management에 의해 heap영역에 10을 저장할 메모리를 할당하여 저장한 뒤, 할당된 메모리의 주소를
'a'라고 지정하는 것이다.


만약,

a = 1, b = 1

이라고 하면,

heap영역에 10을 저장할 메모리를 '하나'를 할당하여 저장한 뒤 할당된 메모리의 주소를
'a', 'b'라고 지정한다.

즉, 'a'와 'b'는 이름만 다른 하나의 메모리 공간과 주소를 공유하는 것이다.
다음은, a = a + 1 일때의 경우
heap영역에 같은 메모리 공간에 값을 바꾸는게 아니라 11을 저장할 메모리를 할당하여 저장한 뒤, 할당된 메모리의 주소를
'a'라고 지정하는 것이다.
만약, a = 10, b = 10, a = a + 1일때 a is b의 결과는 False가 된다. 왜냐?
a의 주소는 값이 변함에 따라 주소도 바꼈기 때문이다.

그렇다면, heap에 있는 메모리가 더이상 사용하지 않은 쓰레기 메모리가 되면 메모리를 관리하는 python memory management는 이를 어떻게 처리할까?
python에서는 가비지 컬랙션을 레퍼런스 카운팅을 통해 Number of references 가 0이 될 때 메모리 할당을 해제하게 된다

반응형