timeval 型の値を印刷しようとしています。実際には印刷できますが、次の警告が表示されます。
この行に複数のマーカーがあります
- フォーマット '%ld' は型 'long int' を想定していますが、引数 2 は型 'struct timeval' です
プログラムはコンパイルされ、値が出力されますが、何か間違っているかどうかを知りたいです。ありがとうございます。
printf("%ld.%6ld\n",usage.ru_stime);
printf("%ld.%6ld\n",usage.ru_utime);
使用法はタイプ
typedef struct{
struct timeval ru_utime; /* user time used */
struct timeval ru_stime; /* system time used */
long ru_maxrss; /* maximum resident set size */
long ru_ixrss; /* integral shared memory size */
long ru_idrss; /* integral unshared data size */
long ru_isrss; /* integral unshared stack size */
long ru_minflt; /* page reclaims */
long ru_majflt; /* page faults */
long ru_nswap; /* swaps */
long ru_inblock; /* block input operations */
long ru_oublock; /* block output operations */
long ru_msgsnd; /* messages sent */
long ru_msgrcv; /* messages received */
long ru_nsignals; /* signals received */
long ru_nvcsw; /* voluntary context switches */
long ru_nivcsw; /* involuntary context switches */
}rusage;
struct rusage usage;
ベストアンサー1
GNU Cライブラリ、struct timeval
:
sys/time.h で宣言されており、次のメンバーがあります。
long int tv_sec
これは経過時間の秒数を表します。
long int tv_usec
これは経過時間の残り(1 秒未満)で、マイクロ秒数で表されます。常に 100 万未満です。
だからあなたは
printf("%ld.%06ld\n", usage.ru_stime.tv_sec, usage.ru_stime.tv_usec);
のように「適切にフォーマットされた」タイムスタンプを取得します1.000123
。