[C] 동적 메모리 할동, 사용후 해제시에 오류..
글쓴이: oldbell / 작성시간: 금, 2004/11/12 - 11:20오전
아래와 같이 썼는데..
#include <string.h> int main() { char section_name[] ="dirdir=1223"; char *p; char search[] = "="; int usize; usize = strlen(section_name) + 1; p = (char *)malloc(usize); sprintf(p,"init *p by sprintf()"); printf("%s\n",p); memset(p, 0x00, usize); p = strtok(section_name,search); printf("%d %s:%s\n",strlen(p),section_name,p); free(p); return 0; }
Quote:
init *p by sprintf()
6 dirdir:dirdir
Segmentation fault
위와 같은 오류가 납니다....
Forums:
free
p = strtok(section_name,search);
이 부분에 문제가 있습니다.
포인터 p가 malloc으로 생성된 영역을 가리키고 있다가.
strtok가 리턴하는 영역을 가리키도록 바뀌었습니다.
그러므로 free가 될 수 없습니다.
p가 가리키는 영역에 쓰기위해서는
sprintf나 ..memcpy 등을 사용하시면 됩니다.
strtok(3)은 주어진 첫번째 인자가 가리키는 메모리에 있는 문자열을
strtok(3)은 주어진 첫번째 인자가 가리키는 메모리에 있는 문자열을 끊어서 그 토큰에 대한 포인터를 리턴합니다. malloc(3) 부를 필요 없습니다.
쓰신 코드가 segfault가 난 원인은, free(3)에 전달된 값이 malloc(3)으로 얻은 게 아니기 때문입니다.
C FAQ: http://www.eskimo.com/~scs/C-faq/top.html
Korean Ver: http://cinsk.github.io/cfaqs/
:) 감사합니다.
:) 감사합니다.
인생의 무게를 느껴라. 아는 만큼 보이는게다.
기본적으로 메모리 할당과 사용에도 문제가 있는거 같네요.. usiz
기본적으로 메모리 할당과 사용에도 문제가 있는거 같네요..
usize = strlen(section_name) + 1;
p = (char *)malloc(usize);
위에서는 보면 usize는 12. 따라서 메모리는 12바이트 만큼 잡아 놓고,
sprintf(p,"init *p by sprintf()");
위에서는 실제 그 이상의 문자를 쓰면, 뒷부분의 메모리를 겹쳐 쓰게 되면서.....
또 다른 문제가 발생할 소지가 충분한듯 하네요..
댓글 달기