링크드 리스트 구현시 malloc 관련 에러 입니다.
희미해
소스내용은 파일을 한줄씩 읽어서 파싱해서 구조체에 넣고 링크드리스트로 만드는 겁니다.
그런데 한 300개까지는 잘 되디가 중간에 에러가 발생하네요.
에러 내용은 다음과 같습니다.Windows가 Journals.exe에서 중단점을 트리거했습니다.
힙이 손상되어 Journals.exe 또는 여기서 로드한 DLL에 버그가 있을 수도 있습니다.
Journals.exe에 포커스가 있을 때 사용자가 F12 키를 눌렀기 때문일 수도 있습니다.
자세한 진단 정보는 [출력] 창을 참조하십시오.
아래 소스에서 보시면 동적할당을 하는current =(LINK)malloc(sizeof(BOOK));부분에서 에러가 발생하는것 같은데.. 원인을 모르겠네요.맨날 자바만 하다가 C를 할려니 힘드네요..ㅠㅠ
풀 코드 입니다.더럽더라도 이해를...ㅠㅠ
#include stdio.h#include stdlib.h#include string.h#include memory.h
struct journal{ char no[5]; char title[50]; char priodical[15]; char ISSN[16]; char addr[100]; char nation[15]; struct journal * next;};
typedef struct journal BOOK;typedef BOOK *LINK;
int main(void){ FILE *in, *out; char buff[300]; LINK head = NULL; LINK prev = NULL; LINK current = NULL; LINK *buf = NULL; int i;
in = fopen(journalscopy.csv, rt); if(in == NULL) { printf(Cannot open file \n); exit(1); } out = fopen(journals.sort,w); if(out == NULL) { printf(Cannot open output file \n); exit(1); } i = 0; //buf = (LINK *)malloc(9000*sizeof(BOOK)); //buf = (LINK *)calloc(9000,sizeof(BOOK)); if(buf!=NULL) printf(Memory Allocation Success\n); else printf(Memory Allocation Fail\n);
while(fgets(buff, 300 ,in) && !feof(in)){ printf(%d,i); if(i==0){ } else{ //current = buf[i-1]; current =(LINK)malloc(sizeof(BOOK)); if(current!=NULL) printf(Memory Allocation Success\n); else printf(Memory Allocation Fail\n); printf(%d set buf,i); if(head == NULL){ //insert data to prev head = current; printf(%d set head,i); } else{ //insert data to prev prev-next = current; printf(%d set next node,i); } current-next = current; printf(%d insert data,i); strcpy(current-no,strtok(buff,,)); strcpy(current-title,strtok(NULL,,)); strcpy(current-priodical,strtok(NULL,,)); strcpy(current-ISSN,strtok(NULL,,)); strcpy(current-addr,strtok(NULL,\)); strcpy(current-nation,strtok(NULL,,)); printf(%d insert data end\n,i); prev = current; } i++; }
if(head-next ==NULL) printf(head.next = NULL\n); current = head; while(current != NULL){ printf(fputs %s\n,current-no); /*fputs(current-no,out); fputs( , ,out); fputs(current-title,out); fputs( , ,out); fputs(current-priodical,out); fputs( , ,out); fputs(current-ISSN,out); fputs( , ,out); fputs(current-addr,out); fputs( , ,out); fputs(current-nation,out);*/ current = current-next; } free(buf); fclose(in); fclose(out);
return 0;}