# 메모리 영역의 구성
메모리 영역은 위와 같이 구성되는데 "가상 메모리의 구성" 이다.
스택 영역은 주로 지역변수, 매개변수, 함수의 반환값, 함수 호출의 주소 등이 저장된다.
힙영역은 주로 동적 할당을 할 때 사용되는 영역인데 다들 잘 알듯이
c++에서 new, delete이 c 에서 malloc, free 등이 있는데 동적 할당을 하고 사용을 했으면 해제 하는것에도 주의를
기울여 주어야 할것이다.
# 다른 영역의 메모리를 사용할 때의 속도의 차이는 어떻게 될까?
- 이를 한번 알아보도록 하자.!
- 배열은 int 형으로 크기는 10000
- 충분한 횟수의 함수 호출(1000001)
-#include<time.h> , clock_t 를 이용한 시간 계산
1. 배열을 정적영역에 선언해서 할당 받는 함수.
2. 배열을 스택영역에 선언해서 할당 받는 함수.
3. 배열을 힙영역에 선언해서 할당 받는 함수.
코드의 이해는 어렵지 않을 것이다. 다음과 같다.
결과는 어떻게 될까?.....
<결과화면>
위와 같다. 시간 자체 값은 변경될수 있지만
비교를 해보면
정적영역에 선언 < 스택영역에 선언 < 힙영역에 선언
순이다.
동적할당의 경우
-컴퓨터의 저장소는 < 레지스터 / 캐쉬 L1 / 캐쉬 L2 / memory / HDD >
순으로 왼쪽에 있는 저장장치 일수록 속도가 빠르고 용량이 작으며 용량당 가격이 비싸다.
오른쪽으로 갈수록 느리지만 용량이 크고 값이 싸다
그래서 OS에게 요청해서 memory allocation 은 memory에서 일어나므로 느릴수 밖에 없다.
일반적인 힙 성능 문제들이 있다.
- 할당 작업으로 인한 속도 저하
만약 사용가능한 블록이 사용가능 목록에 없다면 런타임에 더 큰 블록을 찾거나 새블록을 할당 받아와야한다.
- 해체 작업으로 인한 속도저하
- 힙 경합으로 인한 속도 저하
두개이상의 쓰레드가 접근 하려고 하는 경우 한 쪽 작업이 완료되어야 접근가능
-힙 손상으로 인한 속도 저하
알고 싶었던 내용과 그러한 현상이 나타난 이유를 기재 해보았습니다.
틀린 부분이 있을 수 있습니다. 알려주시면 수정하겠습니다. !