计时接口(Linux/Cpp)

15 篇文章 0 订阅

在这里插入图片描述

/* InterFace/Linux/TimeCal.c */
#include "TimeCal.h"

int startTime(TimeCal *timer)
{
    if (clock_gettime(CLOCK_MONOTONIC, &timer->start) != 0)
    {
        perror("clock_gettime");
        return -1;
    }

    return 0;
}

int stopTime(TimeCal *timer)
{
    if (clock_gettime(CLOCK_MONOTONIC, &timer->end) != 0)
    {
        perror("clock_gettime");

        return -1;
    }
    return 0;
}

long getElapsedTime(const TimeCal *timer, int unit)
{
    long seconds = timer->end.tv_sec - timer->start.tv_sec;
    long nanoseconds = timer->end.tv_nsec - timer->start.tv_nsec;

    switch (unit)
    {
    case 1: // 返回秒
        return seconds;
    case 2: // 返回毫秒
        return seconds * 1000 + nanoseconds / 1000000;
    case 3: // 返回微秒
        return seconds * 1000000 + nanoseconds / 1000;
    default:
        return -1; // 无效的单位
    }
}

void timeUsleep(unsigned int time)
{
    usleep(time);
}

/* InterFace/Linux/TimeCal.h */
#pragma once
#include <stdio.h>
#include <time.h>
#include <unistd.h> 
#include <memory.h> 

#ifdef __cplusplus
extern "C" {
#endif

typedef enum _TIME_TYPE
{
    _SECONDS = 1,
    _MILLISECONDS,
    _MICROSECONDS
}TIME_TYPE;

typedef struct _TimeCal
{
    struct timespec start;
    struct timespec end;
}TimeCal;

extern int startTime(TimeCal *timer);
extern int stopTime(TimeCal *timer);
long getElapsedTime(const TimeCal *timeCal, int unit);
extern void timeUsleep(unsigned int time);

#ifdef __cplusplus
}
#endif
/* InterFace/Cpp/TimeCal.c */
#include "TimeCal.h"

int startTime(TimeCal *timeCal)
{
    timeCal->start = std::chrono::steady_clock::now();
    return 0;
}

int stopTime(TimeCal *timeCal)
{
    timeCal->end = std::chrono::steady_clock::now();
    return 0;
}

long getElapsedTime(const TimeCal *timeCal, int unit)
{
    using namespace std::chrono;

    auto duration = timeCal->end - timeCal->start;

    switch (unit)
    {
    case 1: // 返回秒
        return duration_cast<seconds>(duration).count();
    case 2: // 返回毫秒
        return duration_cast<milliseconds>(duration).count();
    case 3: // 返回微秒
        return duration_cast<microseconds>(duration).count();
    default:
        return -1; // 无效的单位
    }
}

void timeUsleep(unsigned int time)
{
    std::this_thread::sleep_for(std::chrono::microseconds(time));
}

/* InterFace/Cpp/TimeCal.h */
#pragma once

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

#include <iostream>
#include <chrono>
#include <thread>

typedef enum _TIME_TYPE
{
    _SECONDS = 1,
    _MILLISECONDS,
    _MICROSECONDS
}TIME_TYPE;

typedef struct _TimeCal
{
    std::chrono::steady_clock::time_point start;
    std::chrono::steady_clock::time_point end;
} TimeCal;

extern int startTime(TimeCal *timer);
extern int stopTime(TimeCal *timer);
long getElapsedTime(const TimeCal *timeCal, int unit);
extern void timeUsleep(unsigned int time);

/* InterFace.h */
#pragma once

/* Cmake input */
// #define _USE_LINUX 1
// #if _USE_LINUX
// #define _USE_CPP 0
// #else
// #define _USE_CPP 1
// #endif

#if _USE_LINUX
#include "InterFace/Linux/TimeCal.h"
#elif _USE_CPP
#include "InterFace/Cpp/TimeCal.h"
#endif

/* main.c */
#include "InterFace.h"

int main()
{
    TimeCal timer;
    memset(&timer, 0, sizeof(timer));

    int unit = _MICROSECONDS; // 选择时间单位:1-秒,2-毫秒,3-微秒

    startTime(&timer);
    timeUsleep(1000000);
    stopTime(&timer);

    long elapsed_time = getElapsedTime(&timer, unit);

    if (elapsed_time >= 0)
    {
        printf("Time taken: %ld %s\n", elapsed_time, (unit == 1) ? "seconds" : ((unit == 2) ? "milliseconds"
                                                                                           : "microseconds"));
    }
    else
    {
        printf("Invalid time unit selected.\n");
    }

    return 0;
}
cmake_minimum_required(VERSION 3.5)
project(MyProject)
set(CMAKE_VERBOSE_MAKEFILEON)
add_compile_options(-std=c++11 -Wall)

# 添加条件语句,选择不同路径下的源文件
if (_USE_LINUX)
    add_definitions(-D_USE_LINUX=1)
    file(GLOB SOURCE_FILES main.c InterFace/Linux/*.c)
#    set(SOURCE_FILES main.c InterFace/Linux/TimeCal.c)
#elseif (_USE_CPP)
#    add_definitions(-D_USE_CPP=1)
#    set(SOURCE_FILES main.c InterFace/Cpp/TimeCal.c)
else()
    add_definitions(-D_USE_CPP=1)
    file(GLOB SOURCE_FILES main.c InterFace/Cpp/*.c)
endif()

# 设置可执行文件的输出路径
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${PROJECT_SOURCE_DIR}/build)

# 添加源文件
add_executable(MyExecutable ${SOURCE_FILES})

# 添加包含路径
target_include_directories(MyExecutable PRIVATE ${PROJECT_SOURCE_DIR})

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值