我正在使用两种方法对将x行相同文本写入文件进行一些微不足道的基准测试:
-
直接重写。
-
创建一个新线程,通信通过异步队列完成(主线程在一侧插入,另一侧线程从另一侧读取)。此方法用于尝试最小化最慢的写入(由于刷新)
这是一段代码,应该给出程序的基本概念:
int i;
char * buf;
int buf_size;
double local_start, local_end, global_start, global_end;
double slowest, fastest;
double local_time_difference;
buf = "A string to be printed to a file n";
buf_size = strlen(buf);
fastest = MAX_WRITE_TIME;
slowest = 0;
logger_init(atoi(argv[1]));
global_start = get_time();
for(i = 0 ; i < 100000000 ; i++)
{
local_start = get_time();
logger_write(buf, buf_size);
local_end = get_time();
local_time_difference = local_end-local_start;
if(local_time_difference < fastest && local_time_difference != 0)
fastest = local_time_difference;
if(local_time_difference > slowest)
slowest = local_time_difference;
if(i % 10000 == 0)
usleep(1);
}
global_end = get_time();
printf("Fastest: %1.9fnSlowest: %1.9fnTotal Time: %1.9fn", fastest, slowest, global_end-global_start);
logger_destroy();
获取时间过程返回时间(以微秒为单位)
double get_time()
{
struct timeval t;
struct timezone tzp;
gettimeofday(&t, &tzp);
return t.tv_sec + t.tv_usec*1e-6;
}
根据传递给logger_init的参数,logger_write将直接写入文件或将其插入队列(队列的大小不得超过某个特定限制)。GAsyncQueue 正在使用中
我目前用来计算最快和最慢写入的方法当然有效,但我的问题是:是否有工具或分析器可以为我执行此操作? 即给我关于每个函数的统计信息(最大、最小和平均调用)
到目前为止我已经尝试过但没有运气的工具:
- GPROF
- 缩放
- Kcachegrind
- VTune
TL:DR我正在寻找一种工具,为我提供特定函数的最小、最大和平均执行时间,而不是所花费的总时间。
- 使用正确的高分辨率操作系统 API 函数进行基准测试。
- 不要从测量本身内部计算执行时间,尤其是在使用浮点数时。
- 为什么要调用睡眠函数?您是否试图强制上下文切换或类似的东西?操作系统可能会比你的程序更好、更高效地处理这些。