[완료] sqlite3 리턴 포인터 다르게 받는 방법
글쓴이: jazzsir / 작성시간: 수, 2011/10/12 - 5:15오후
sqlite3 D/B의 테이블에 여러 행들이 저장되어 있고
아래와 같이 반복문으로 PHONE_NAME이라는 칼럼을 모두 가져오도록 하는데..
for(i=0; i<total; i++) { int ret = sqlite3_step(stmt); student[i].name = (char*)sqlite3_column_text(stmt,PHONE_NAME)); . . . }
student[0].name, student[1].name, student[2].name......
모두 같은 포인터를 가리키고 있어서 결국엔 마지막값으로 통일돼버리네요. --;
(student.name은 "문자 배열"인 아닌 "문자형 포인터"입니다.)
그래서 아래와 같이 malloc으로 메모리를 할당해서 strcpy로 했는데
for(i=0; i<total; i++) { int ret = sqlite3_step(stmt); char * name = (char*)sqlite3_column_text(stmt,PHONE_NAME); student[i].name=(char *)malloc(sizeof(strlen(name4call)+1)); memset(student[i].name,0x00,sizeof(strlen(name4call)+1)); strcpy(student[i].name,name4call); . . . }
5번정도 루프를 돌고 죽어버리네요. --;
질문 :
1) 뭐가 문제일까요??
2) embedded환경이라 자원이 제한적입니다. 그래서 strcpy를 안써고 각각 포인터에 저장하는 방법이 있을까요?
3) 위의 경우 student도 malloc으로 할당했습니다.
메모리 해제시 free(student)만 하면 되는지 아님 free(student[n].name)도 해줘야 하는지 궁금합니다.
감사합니다.
Forums:
for(i=0; i<total; i++) { int
감사합니다.~
많은 도움 되었습니다. 감사합니다~ ^^
댓글 달기