구조체 동적 할당 방법?
      글쓴이: ssik425 / 작성시간: 화, 2004/08/10 - 7:45오후    
  
  링크드 리스트 등을 사용하지 않고 동적 할당  자료형을 구현 해보려고 하는데
안되네요.. 아직은 허접인지라  :oops: 
코드는 아래와 같습니다. 여러분들은 어떻게 처리하시나요?
폴트가 나는거 보니 제가 잘못한거 같은데 뭐가 틀린 거죠?
/* 구조체 동적 할당 testing */
typedef struct Cnt {
   int num1;
   char num2[10];
}COUNT;
int main(void)
{
   int i=0;
   COUNT *cnt;
   cnt=(COUNT *)malloc( sizeof(COUNT));
   save_data(cnt);
   for(i=1;i<100;i++)
      printf("%d %s \n", cnt[i].num1, cnt[i].num2);
   return 0;
}
int save_data(COUNT *cnt)
{
   int i=0;
   for(i=1;i<100;i++)
   {
      cnt=(COUNT *)realloc(cnt, (sizeof(COUNT) * i));
      memset(cnt + (sizeof(COUNT)*i), 0x00,sizeof(COUNT));
      cnt[i].num1=i;
      sprintf(cnt[i].num2, "%d", i);
   }
   return 0;
}Forums: 


Re: 구조체 동적 할당 방법?
이렇게 하면 되긴되지만..
차라리 링크드 리스트를 쓰시는게 정신 건강에 좋으실듯 8)
-----------
청하가 제안하는 소프트웨어 엔지니어로써 재미있게 사는 법
http://sozu.tistory.com
넵 감사합니다.링크드 리스트를 쓰기에는 뭔가 허전 해서요 ^^
넵 감사합니다.
링크드 리스트를 쓰기에는 뭔가 허전 해서요 ^^
개발자들의 궁극적 비전은 ?
포인터 연산을 잘못 하셨군요.[code:1]int save_dat
포인터 연산을 잘못 하셨군요.
int save_data(COUNT *cnt) { for(i=0;i<100;i++) { cnt=(COUNT *)realloc(cnt, (sizeof(COUNT) * (i+1))); memset(cnt + i, 0x00, sizeof(COUNT)); // 여기 cnt[i].num1=i; sprintf(cnt[i].num2, "%d", i); } return 0; }cnt가 COUNT*이므로 cnt + i는 cnt + sizeof(COUNT)*i 번지를 가리키는
COUNT*가 됩니다.
어떤 자료구조를 구현하려고 하시는지는 잘 모르겠지만 realloc을 루프 안에
넣는 것은 별로 좋지 않은 방법입니다. 미리 필요한 메모리를 계산해서 한 번에
할당하든지, 처음부터 좀 넉넉하게 할당하든지 해서 realloc을 호출하는 횟수를
줄이는 편이 좋습니다.
댓글 달기