UNIXプログラミング。struct timevalの印刷方法(Cプログラミング)質問する

UNIXプログラミング。struct timevalの印刷方法(Cプログラミング)質問する

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

おすすめ記事