時刻取得機能

秒数後に、この特定の時間1970-01-01 0時00分00秒0000(UTC)以降のLinuxカーネルによって提供される基本的な時間は、この説明は、我々はカレンダーを呼び出してデータtime_t型の表現に基づいており、時間。
時間、にclock_gettimeとgettimeofdayの三つがあるカレンダ時刻を取得する機能。

時間関数

#include <time.h>

//成功返回日历时间,出错返回-1;若time非NULL,则也通过其返回时间值
time_t time(time_t *time);
#include <stdio.h>
#include <string.h>
#include <time.h>

void print_time()
{
    time_t seconds = time(NULL);

    printf("seconds = %ld\n", seconds);
}

int main()
{
    print_time();

    return 0;
}

clock_gettime機能

clock_gettime関数は、指定されたクロック時間を取得し、構造体timespec構造体によって保存された時間を返し、構造及び時間は秒ナノ秒単位で表されます。

#include <time.h>

struct timespec
{
    time_t   tv_sec;        /* seconds */
    long     tv_nsec;       /* nanoseconds */
};

//Link with -lrt.
int clock_gettime(clockid_t clock_id, struct timespec *tsp);

clock_idは、一般的に設定されCLOCK_REALTIME、高精度のカレンダ時刻を取得します。

#include <stdio.h>
#include <string.h>
#include <time.h>

void print_time()
{
    time_t seconds;
    struct timespec tsp;

    seconds = time(NULL);
    printf("seconds = %ld\n", seconds);

    clock_gettime(CLOCK_REALTIME, &tsp);
    printf("tsp.tv_sec = %ld, tsp.tv_nsec = %ld\n", tsp.tv_sec, tsp.tv_nsec);
}

int main()
{
    print_time();

    return 0;
}

gettimeofdayの機能

gettimeofdayによるにclock_gettime機能等は、時間は秒と微妙に表現されるカレンダ時刻いるstruct timeval構造体を返します。

#include <sys/time.h>

struct timeval
{
    time_t      tv_sec;     /* seconds */
    suseconds_t tv_usec;    /* microseconds */
};

int gettimeofday(struct timeval *tv, struct timezone *tz);

唯一の合法的なTZパラメータ値がNULLであることに留意すべきです。

#include <stdio.h>
#include <string.h>
#include <time.h>
#include <sys/time.h>

void print_time()
{
    time_t seconds;
    struct timespec tsp;
    struct timeval tv;

    seconds = time(NULL);
    printf("seconds = %ld\n", seconds);

    clock_gettime(CLOCK_REALTIME, &tsp);
    printf("tsp.tv_sec = %ld, tsp.tv_nsec = %ld\n", tsp.tv_sec, tsp.tv_nsec);

    gettimeofday(&tv, NULL);
    printf("tv.tv_sec = %ld, tv.tv_usec = %ld\n", tv.tv_sec, tv.tv_usec);
}

int main()
{
    print_time();

    return 0;
}

おすすめ

転載: www.cnblogs.com/songhe364826110/p/11546104.html