printf로 long형을 출력하려면 어떻게 하나요?
글쓴이: yamong / 작성시간: 목, 2003/04/17 - 10:24오후
printf로 long형을 출력하려고 합니다. long형을 출력하는 방법을 가르쳐 주세요....
시간이 되신다면 아래의 소스 코드 좀 봐주세요. 프로세스의 수행 시간을 측정 하려고 하는 데요....
#include <sys/time.h>
main()
{
struct timeval t1, t2;
long dif-sec,;
gettimeofday(&t1, 0);
//수행 될 작업들....
gettimeofday(&t2, 0);
dif-sec = t1.tv(언더 바)sec - t2.tv(언더 바)sec;
printf("%d", dif-sec);
return 0;
}
위 처럼 하면 안되나요? sys/time.h를 확인해 보았는데... gettimeofdat()는 있더군요. 그런데 실행 하면 0이 나옵니다. 원래는 몇초가 나와야지 정상인데....
Forums:
long 형 출력은 %d 대신에 %ld 로 하시구요..그리고 그냥 s
long 형 출력은 %d 대신에 %ld 로 하시구요..
그리고 그냥 sec 대신에 usec? 으로 하셔야 할 겁니다..
(갑자기 이름이 생각 안 나서 확실치는 않음..)
sec은 초단위이고, usec이 100만분의 1초 단위이죠..
자세한건 man 페이지 참고
%d대신 %ld를 쓰세요. 후진 C책이 아니라면 printf format
%d대신 %ld를 쓰세요. 후진 C책이 아니라면 printf format string에 대해서 잘 나와 있을 겁니다. scanf() 매뉴얼 페이지에도 잘 나와 있습니다.
그리고 시간 측정은 tv_sec말고 tv_usec까지 감안하셔야 할 겁니다.
--
익스펙토 페트로눔
일반적으로 16bit 컴파일러를 쓰지 않는 이상은그냥 %d 만 쓰
일반적으로 16bit 컴파일러를 쓰지 않는 이상은
그냥 %d 만 쓰셔도 long 까지 지원이 됩니다. 32bit 컴파일러에서는
int 와 long 의 사이즈가 같습니다.
그럼 고운 하루
=========================
CharSyam ^^ --- 고운 하루
=========================
char & unsigned char = %cint = %duns
char & unsigned char = %c
int = %d
unsigned int = %u
long = %ld
unsigned long = %lu
float = %f
double = %lf
string(char array NULL terminated) = %s
.지우.
s(˘∼˘*)z,·´″"`°³о$ √(´∀`√)... (˘ヘ˘ㆀ)a
[quote="xjiwoox"]float = %fdouble = %l
float, double 모두 %f 입니다 - 기본 인자 진급에 의해 printf() 입장에서
는 float/double 형을 구분할 수 없습니다 - 두 경우 모두 double 형을 받
습니다.
%lf 는 C90/C95 표준에서는 정의되지 않은 행동에 해당하며, C99 에서는 다
행스럽게도 %f 와 동일하도록 정의되어 있습니다.
참고로, long double 은 %Lf 입니다.
그럼...
--
Jun, Woong (woong at gmail.com)
http://www.woong.org
댓글 달기