포인터 제어와 관련된 기초적인 질문이 있습니다.
글쓴이: opnc / 작성시간: 금, 2005/08/19 - 1:15오후
포인터 제어와 관련되어 궁금한 점이 있어 글을 올립니다.
함수에서 지역변수로 배열을 선언한 후,
이를 포인터로 리턴하면 컴파일 시 warning 이 발생합니다.
예로...
char* pTestFunc()
{
char pTest[10] = {0,};
strcpy(pTest, "Test");
return pTest;
}
int main()
{
char* pRet = pTestFunc();
return 0;
}
위와 같은 코드를 컴파일한 후 실행하면
원하는 결과가 나오긴 합니다만,
warning 이 발생한다는 점이 마음에 걸립니다.
위와 같은 형식으로 코드를 작성하면,
문제가 발생할 소지가 있는건지 궁금하네요..
그럼, 답변 부탁드릴께요..
Forums:
잘 모르지만...
위 배열은 heap이 아닌 함수 스택에 저장되는 것 아닌가요?
따라서 함수가 리턴된 후 에는 그 공간이 버려지고 다른 함수가 필요로 할 때 다시 내주는 공간일 것 같은데... 당장은 동작하는 것 같지만.
지역변수인 pTest 배열안의 값을 사용하고자 한다면 static 으로
지역변수인 pTest 배열안의 값을 사용하고자 한다면 static 으로 선언해야 하지 않을까요?
char pTest[10] = {0,}
----------->
static char pTest[10]={0,}
dangling reference라고 하지요.char pTest[
dangling reference라고 하지요.
char pTest[10] 이 기억장소는,
char* pTestFunc() 함수가 불린 순간에(이 함수내에 수행중)만 존재(스택)하고,
이 함수를 빠져나가면, 없어지는(관리되지 않는) 메모리가 됩니다.
없어진 메모리의 번지를 가지고 있는 char* pRet 는 마치 죽은 자식 x랄 만지는 격입니다. 언제 그 메모리번지가 다른 용도로 사용될지 알 수 없으니 말입니다.
단지 warnning 후 당장 동작 하는건 운이 좋은 경우입니다.실전
단지 warnning 후 당장 동작 하는건 운이 좋은 경우입니다.
실전에서는 어떠한 일이 일이 날지 알 수가 없습니다.
그러므로 이러한 경우는 전역 변수로 배열을 선언해서 사용하시거나 아니면, pointer를 malloc으로 잡아서 사용하는 방법등을 이용 하셔야 할듯합니다.
함수 내에서 선언된 배열은 함수를 벗어나는 순간 메모리가 해제됩니다.
<어떠한 역경에도 굴하지 않는 '하양 지훈'>
#include <com.h> <C2H5OH.h> <woman.h>
do { if (com) hacking(); if (money) drinking(); if (women) loving(); } while (1);
C의 FAQ 군요.
C를 공부하면 누구나 다 한번쯤 거쳐가는 의문인 것 같습니다.
지역변수는 스택에 저장되기 때문에 절대 지역변수의 포인터를 리턴하여 사용
지역변수는 스택에 저장되기 때문에 절대 지역변수의 포인터를 리턴하여 사용해서는 안됩니다..
스택이란 것에 대해서 찾아보시면 어째서 그런지 잘 알게 되실 것입니다.
당장은 잘 되더라도 (아마 디버그로 컴파일 하신듯.. 릴리즈로 컴파일 해보세요. 컴파일러 최적화로 바로 빽 거리며 죽을겁니다.) 언제 어디서 배를 쨰며 눕게 될지 모릅니다..
-------------------------------------------------------------------------------
It's better to appear stupid and ask question than to be silent and remain stupid.
[quote="chadr"]당장은 잘 되더라도 (아마 디버그로 컴파일
한참 생각했습니다. 아무래도 어제 밤샌 후유증인듯. :oops:
gcc -g foo.c
언제나 시작
전역변수 필요없이......
제가 보기에는 함수의 파라미터로 버퍼를 던져주는 방법이 가장 좋을듯 싶은데요....
최대한 전역변수의 수를 줄이는것이 좋습니다.
정확히 어떤 의도로 사용하실지는 모르겠지만 보통 저런 경우에는 파라미터를 버퍼를 받고 그 버퍼에 내용을 담아 주는 방법으로 사용하지요.
int foo(char *buf, int bufsize)
{
if ( size ... ) return -1;
strcpy(buf, "Test");
return 0;
}
/***************************************************
* 가장 심플한 것이 가장 아름다운 것이다.
***************************************************/
댓글 달기