최근 프로그래밍 도중 아주 이상한 현상을 경험했습니다.
글쓴이: chasin / 작성시간: 월, 2010/11/22 - 8:24오후
그림에 표현된 부분에서 파일을 아주 많이 읽고 닫고를 반복합니다. 물론 다 다른 파일입니다.
또한 동시에 수백 개를 여는 것은 아닙니다.
근데, 이 부분에서 파일 오픈 횟수가 489번째 되면 프로그램이 while 부분에서 아무런 메세지
출력없이 죽어버립니다.
그래서 제가 if(TFN>488)이란 구문을 일부러 넣었습니다. 488번째까지 이상없이 실행되는 것을 보면
이 함수 부분에서 별 다른 문제는 없어보입니다.
이 화일들외에 프로그램의 다른 부분에서 임시 파일 포함하여 대충 10개 정도 열려 있는 걸 포함하면
gcc에서 처리할 수 있는 파일 갯수에 제한이 있는 건가요?(동시에 오픈할 수 있는 파일 갯수가 아님)
동시에 오픈할 수 있는 파일 갯수는 헤드파일에서 변경하여 컴파일 할 정도는 됩니다.
대충 500개 정도가 limit(동시에 오픈할 수 있는 파일 갯수를 말하는 게 아님) 같은데, 확실히 알 수가 없네요.
Head file 찾아봐도 이런 변수는 정의된 게 없는 거 같고요.
혹시 이런 경험 하신 고수분 안계신가요? 한 수 지도 부탁드립니다.
for(i=0;i<n_part;i++) { if(PD[i].zflag==0&&PD[i].pc>=ms_pc&&PD[i].rflag==0) { ++TFN; fLN=max_s=lat_s=0; memset(s,0,sizeof(s)); if((part=fopen(strcat(itoa(PD[i].pd,s,10),"_internal.cur"),"rt"))==0) { printf("\n\n\aFile '%s' in %s not exists.",s,strcat(d,"/data")); sTOP(); } else part=fopen(strcat(itoa(PD[i].pd,s,10),"_internal.cur"),"rt"); if(TFN>488) { printf("\n\n\aMaximum number(488) of files which can be handled was reached !!!"); printf("\nPlease increase value of mass percentage in .csv file !!!"); sTOP(); } else { while((fgets(str,MaxCN+1,part))!=NULL) { // file 489번째에서 파일은 열리지만 file size=0임 if(strspn(str,"* Maxval=")>=10) max_s=fLN; if(strspn(str,"endcurve")==8) lat_s=fLN; fLN++; } } if(max_s==0||lat_s==0) { printf("\n\n\aFile '%s' in %s looks corrupted !!!",s,strcat(d,"/data")); printf("\nPlease check the file !!!"); sTOP(); } else rewind(part); for(j=0;j<max_s+1;j++) fgets(str,MaxCN+1,part); sscanf(str,"%s %s %f %s %s %f",nu,nu,&PD[i].mi,nu,nu,&PD[i].ti); for(j=0;j<lat_s-max_s-2;j++) fgets(str,MaxCN+1,part); fscanf(part,"%f %f",&tim,&PD[i].li); fclose(part); data[a][i].mi=PD[i].mi; data[a][i].li=PD[i].li; data[a][i].ti=PD[i].ti; } }
Forums:
gdb를 이용해서 debugging을 해보니
gdb를 이용해서 debugging을 해보니
"warning : Invalid parameter passed to C runtime function."라는 메세지가 나오네요
이 메시제가 뭐 때문에 나온지 이해가 안되는군요.
if((part=fopen(strcat(itoa(PD
fopen() 을 두 번씩 하고 계시네요. 두개 열고 하나 닫고, 두개 열고 하나 닫고 하는군요.
오옷... 문제가 해결됐습니다. 너무 감사합니다.
오옷... 문제가 해결됐습니다. 너무 감사합니다. 그럼 488번째까지는 왜 되었을까요? 아~~~ 넘 궁금합니다.
댓글 달기