[완료] 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
for(i=0; i<total; i++) { int ret = sqlite3_step(stmt); student[i].name = strdup( (char*)sqlite3_column_text(stmt,PHONE_NAME)) ); . . . } <code> strdup 으로 복사하면 좀 더 깔끔하겠네요. 3. free( student[i].name ); free( student ) 둘 다 하셔야되요.감사합니다.~
많은 도움 되었습니다. 감사합니다~ ^^
댓글 달기