20

タイプ timeval の値を出力しようとしています。実際には印刷できますが、次の警告が表示されます。

この行に複数のマーカー

  • フォーマット '%ld' はタイプ 'long int' を想定していますが、引数 2 のタイプは 'struct timeval' です</li>

プログラムがコンパイルされ、値が出力されますが、何か間違っているかどうかを知りたいです。ありがとう。

    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;
4

6 に答える 6

30

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ます。

于 2009-09-24T02:30:51.753 に答える
9

以来、struct timeval次のように宣言されます。

struct timeval {
    time_t      tv_sec;
    suseconds_t tv_usec;
}

基礎となるフィールドを取得する必要があります。

printf ("%ld.%06ld\n", usage.ru_stime.tv_sec, usage.ru_stime.tv_usec);
printf ("%ld.%06ld\n", usage.ru_utime.tv_sec, usage.ru_utime.tv_usec);
于 2009-09-24T02:26:40.097 に答える
2

ええ、その

int main( void )
{
    clock_t start, stop;
    long int x;
    double duration;
    static struct timeval prev;
    struct timeval now;

    start = clock();  // get number of ticks before loop

    for( x = 0; x < 1000000000; x++ );
    // sleep(100);

    stop = clock();  // get number of ticks after loop

    // calculate time taken for loop
    duration = ( double ) ( stop - start ) / CLOCKS_PER_SEC;

    printf( "\nThe number of seconds for loop to run was %.2lf\n", duration );

    gettimeofday(&now, NULL);
    prev.tv_sec = duration;
    if (prev.tv_sec)
    {
        int diff = (now.tv_sec-prev.tv_sec)*1000+(now.tv_usec-prev.tv_usec)/1000;
        printf("DIFF %d\n",diff);
    }

    return 0;

}
于 2010-11-30T11:52:42.087 に答える
1

はい、 timeval は次のように定義されています

struct timeval { 
    time_t      tv_sec; 
    suseconds_t tv_usec; 
} 

使用する

printf ("%ld.%06ld\n", usage.ru_stime.tv_sec, usage.ru_stime.tv_usec); 

きっと役に立ちます。

于 2009-10-06T11:56:25.280 に答える