2016년 2월 2일 화요일

[C/C++]memcpy 함수와 memset 함수에 대한 간단 사용법









C나 C++로 코딩시,

메모리 관련 사용을 할 때, 에러가 많이 발생하곤 합니다.

특히 동적할당으로 배열이나 구조체 사용시, memse 과 memcpy에 대해 자주 에러가 나곤 

했는데요


왜 이런지 원인을 살펴보니...


원인은 다음과 같음을 예상합니다.


일단 memcpy() 와 memset()의 함수에 대한 설명입니다.





















memset의 경우 말 그대로 해당 영역의 memory 데이터를 c로 초기화 하는 것을 

뜻합니다.

count의 경우 어느정도 영역까지 진행할 것인가를 나타내구요
























memcpy의 경우 *dest의 값을 src의 값으로 복사하는 것을 뜻합니다.

이 경우도 count의 값 만큼 dst의 시작 메모리 주소값에서 부터 메모리 영역에 복사하는 것

입니다.



정적 배열의 경우,

예로, ex) int test[10]의 값을 memset, memcpy 한다고 햇을 때,

정적의 경우 컴파일 시, 메모리 값이 할당 되는 것으로 알고 있습니다.


이미 메모리 주소가 있으며, 

할당된 값에 접근만 하면 되는 것이고,


동적의 경우는 런타임시 실행 되지만,


1차원의 경우에는 그리 큰 문제는 없는데,



2차원의 경우는 조금 다른 문제가 발생합니다.



왜냐하면 메모리 구조가 2차원 적으로 생기지 않았기 때문에

발생하는 문제인데요




(위의 그림에서, 메모리 주소값은 임의로 입력 한 것입니다)




배열의 선언 시, 메모리 할당 되는 정적 배열의 경우는 

메모리 주소값들이 연속적으로 가지게 됩니다. 

배열은 메모리에 연속적으로 저장된다는 특징 때문인데요.

memset과 memcpy의 경우 처음 배열의 주소값을 토대로, 사용자가 지정해준

영역만큼 아래로 메모리 영역의 값에 접근합니다.



동적의 경우는 조금 다른 연산이 필요합니다.




(위의 그림에서, 메모리 주소값은 임의로 입력 한 것입니다)





이런식의 메모리 구성을 하니, 배열의 처음 주소에 항상 접근을하여

초기화를 해줘야 에러를 막을 수 있을 것 같습니다.


그리고 memset에서 주의하실 점은,

int,float 단위로 0이 아닌  양수를 넣을 때 발생합니다.

int test[5];

memset(test,1, count);

로 설정 하시게 된다면, 16843009, 같은 이상한 값을 얻을 수 있습니다.

이는 byte 단위로 연산을 하는 memset의 특징 때문인데요,

0000 0001 / 0000 0001 / 0000 0001 / 0000 0001과 같이 변하게 되는 것이죠


하지만 4byte씩 읽는 int형의 경우는 32bit 를 다 읽음으로써,

16843009의 값이 출력됩니다.

그래서 값을 넣을 때, 16진수로 넣어야 된다고 하는데..

해본 결과 제대로 안나와서 잘은 모르겠습니다.



memset 결과화면 입니다.

(정적 배열)





(동적 배열)




배열 시작 주소값을 계속 넣어줌으로써,

memset이 배열 위치를 제대로 찾아가게끔 구성 하여

값을 얻어내는 화면입니다.



memcpy도 인자로 들어갈 것들만 신경 써준다면, 

원하는 결과값을 얻을 수 있습니다.



(정적 배열)






(동적 배열)







댓글 없음:

댓글 쓰기