2차원 문자열 배열의 리턴 ....
글쓴이: Sailor_moon / 작성시간: 수, 2012/09/19 - 6:28오전
char (*name_Extractor(char* args_c))[128]{ char *str = args_c; char *tok; char word[2][128]; //printf("%s\n", str); tok = strtok(str,"/"); strcpy(word[0], tok); tok = strtok(NULL,"/"); strcpy(word[1], tok); return word; } void main(int argc, char **argv){ char args1[128]; if (argc == 1){ printf("Please input arguments !!\n"); exit(1); } if (argc > 2){ printf("...Checking the your argument folder\n"); } else{ strcpy(args1, argv[1]); char (*p)[128] = name_Extractor(args1); printf("%s\n", p[0]); } }//End of Main
안녕하세요 , 2차원 배열에 대해서 질문 드립니다 .... 말 그대로 , 문자열 인자를 받아온 것에서 ,
"/" 를 기준으로 문자열을 둘로 나누는 부분을 하고 있습니다. 문제는 , ex : photo/*.jpg -> photo 와 *.jpg
그런데 , 이 상태에서, p를 출력해 보면 엉뚱한 값이 나오더군요 .... 분명 2차원 배열을 맞게 리턴해주고 넘겨 받은것 같은데 ....
Forums:
char word[2][128]을 함수 내부 변수로
char word[2][128]을 함수 내부 변수로 선언하고,
word를 return하네요..
함수를 빠져나오는 순간 word는 없어지겠지요..
word를 static으로 선언하시면 될 듯..
--
단순히 2개로 나누려면,
구현하신 함수는 좀 over spec인듯요.
strchr(또는 strrchr)를 사용하시는게 낫지 않을까요?
고맙습니다
가장 기본 적인 부분인데 잘못 알고 있었나 보네요 ....
그런데 보통 파이썬 같은 다른 랭귀지에서는 저렇게 써도 아무런 문제가 없던데 왜 유독 c 에서만 그렇지요 ?
-------------------------------------------
정의의 이름으로 널 ! 용서하지 않겠다 !!
파이썬은 원래 그렇게 되도록 설계한 것이고, C도
파이썬은 원래 그렇게 되도록 설계한 것이고, C도 원래 그렇게 되도록 설계한 거죠.
유독 C만 그런가 하면 그건 아닙니다.
그리고 C언어에서 위와 같은 경우에는 처음부터 값을 되돌려 받을 포인터를 인자로 넣어서 거기에 넣습니다. 다음과 같이 말이죠
피할 수 있을때 즐겨라! http://melotopia.net/b
이제 C에서 stack에 할당되는 메모리와 heap에
이제 C에서 stack에 할당되는 메모리와 heap에 할당되는 메모리의 차이를 공부하실 때가 되셨습니다.
평범하게 선언한 변수는 stack에 할당되는데, stack에 할당된 메모리는 해당 스코프가 끝나면 자동으로 회수되어서 없어집니다.
단순히 변수 대입으로 내용을 복사해 올수 있는 경우는 이게 문제가 안되는데, 배열같이 변수를 복사해도 내용은 복사되지 않는 경우는 메모리를 복사해주거나 스코프를 벗어나도 메모리가 해제되지 않도록 stack이 아닌 heap에 메모리가 할당되게 해주어야 합니다.
왜 파이썬은 되고 C는 안되느냐고 질문하셨는데, 파이썬은 이 과정을 인터프리터가 알아서 해주는 거고 C는 이과정을 프로그래머가 전부 수동으로 해주어야 한다는 게 다를 뿐, 동작원리는 동일합니다.
댓글 달기