vfprintf사용법좀 알려주세용
int
plog(va_alist)
va_dcl
{
va_list args;
char *fmt;
char cur_date[11];
char cur_time[13];
time_t ttime;
struct tm *stm;
ttime = time((time_t *)NULL);
stm = localtime((time_t *)&ttime);
strftime(cur_date, sizeof(cur_date), "%Y-%m-%d",stm);
strftime(cur_time, sizeof(cur_time), "[%H:%M:%S] ",stm);
va_start(args);
fmt = va_arg(args, char *);
sprintf(LogPath_, "%s.%s", LogFileName_, cur_date);
if((lfp_ = fopen(LogPath_, "a+")) == (FILE *)NULL)
{
va_end(args);
fclose(lfp_);
return -1;
}
fprintf(lfp_, cur_time);
vfprintf(lfp_, fmt, args);
va_end(args);
fclose(lfp_);
return(0);
}
이런 코드가 있는데 도데체
va_alist, va_start등등 잘모르겠어요
이거에 대한 설명좀 해주세요
아니면 설명된 곳을 좀 알려주세요
man으로 찾아도 잘 모르겠어요 부탁드립니다.
va_??? 로 시작하는 부분들은 /usr/include/sys/var?
va_??? 로 시작하는 부분들은 /usr/include/sys/var??.h 라는
파일이 있습니다.
여기에서 정의된 함수와 구조체인데...
printf("") 함수인 경우 아래와 같이 사용할수 있죠..
printf("%d %d %d", 1, 2, 3 );
이때 위와 같이 지정된 함수의 인자갯수는 정해지지 않습니다.
일반적인 C 프로그램에서는 함수의 인자갯수가 지정되나 위와 같이
정해지지 않은 갯수의 인자들이 들어오는 경우에 처리하는 것인데...
각각의 인자를 파싱하여 자동적으로 처리하는 부분이 바로
va_??() 함수들입니다....
va_dcl va_alist로 선언된 부분은 바로 위의
"%d %d %d", 1, 2, 3 에 해당되는 부분이구요...
위에서 질문하신 소스가 일반적으로 로그를 출력할때 사용하는 함수인데
로그 앞부분에 시간을 같이 출력하게 하는 것이죠...
그럼.
댓글 달기