- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
看完this article关于运行时间,我写了一个简单的代码来计算一个循环的执行时间:
#include <stdio.h>
#include <sys/time.h>
int main (int argc, char** argv) {
struct timeval, tvalBefore, tvalAfter;
gettimeofday (&tvalBefore, NULL);
int i =0;
while ( i < 1000) {
i ++;
}
gettimeofday (&tvalAfter, NULL);
printf("Time in microseconds: %0.3f microseconds\n",
(float)(tvalAfter.tv_sec - tvalBefore.tv_sec)
)
return 0;
}
clang 编译器给我以下错误:
print_time.c:7:16: error: expected identifier or '('
struct timeval, *tvalBefore, *tvalAfter;
^
print_time.c:13:17: error: use of undeclared identifier 'tvalBefore'
gettimeofday (&tvalBefore, NULL);
^
print_time.c:19:17: error: use of undeclared identifier 'tvalAfter'
gettimeofday (&tvalAfter, NULL);
^
print_time.c:22:12: error: use of undeclared identifier 'tvalAfter'
(float)(tvalAfter.tv_sec - tvalBefore.tv_sec)
^
print_time.c:22:31: error: use of undeclared identifier 'tvalBefore'
(float)(tvalAfter.tv_sec - tvalBefore.tv_sec)
^
5 errors generated.
我不知道我的代码有什么问题,知道吗?
最佳答案
您的代码中有两个输入错误:
struct timeval,
应该是
struct timeval
在 printf()
括号后需要一个分号。
另外,根据编译器的不同,如此简单的循环可能会被优化掉,无论你做什么,都会给你 0 微秒的时间。
最后是时间计算错误。您只考虑秒,忽略微秒。您需要得到秒之间的差异,乘以一百万,然后添加“之后”tv_usec
并减去“之前”tv_usec
。将整数秒数转换为 float 将一无所获。
我建议查看 struct timeval
的手册页。
这是代码:
#include <stdio.h>
#include <sys/time.h>
int main (int argc, char** argv) {
struct timeval tvalBefore, tvalAfter; // removed comma
gettimeofday (&tvalBefore, NULL);
int i =0;
while ( i < 10000) {
i ++;
}
gettimeofday (&tvalAfter, NULL);
// Changed format to long int (%ld), changed time calculation
printf("Time in microseconds: %ld microseconds\n",
((tvalAfter.tv_sec - tvalBefore.tv_sec)*1000000L
+tvalAfter.tv_usec) - tvalBefore.tv_usec
); // Added semicolon
return 0;
}
关于c - 如何使用 struct timeval 获取执行时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12722904/
我如何知道从 1970 年 1 月 1 日 00:00:00 到现在使用 timeval 之间的秒数和微秒数?谢谢。 struct timeval { long tv_sec; /*seconds
我想将 timeval 结构从秒转换为纳秒,实现此目的的最佳算法是什么? 最佳答案 我建议这样做: uint64_t nanosec(struct timeval t) { /* Calculate
我在将 time_t 转换为 struct timeval 时遇到问题。我需要从 time_t 值填充 tv_usec 和 tv_sec 值。 为了填充tv_sec和tv_usec,我们需要调用get
我正在尝试打印 struct timeval 变量中的值,如下所示: int main() { struct timeval *cur; do_gettimeofday(cur)
我正在尝试将这两个组件从时间结构中拉出并将它们放入字符串中。 我运气不太好。我尝试先将其转换为长整数,然后再转换为字符串。我需要最有效的方法来执行此操作。 有什么想法吗?我不想首先转换为另一个数据结构
我需要使用两个 integer 参数 p1 和 p2 来表示 timeval 结构。我已将 tv_sec 复制到 p1 并将 tv_usec 复制到 p2。在 32 位 (centos) 中 size
通过下面的代码,我可以获得以毫秒为单位的当前时间。现在我想将毫秒添加到系统时间。有什么提示吗? #include #include int main (int argc, char** argv)
如何将 timeval 转换为 time_t?我正在尝试转换:umtp->ut_tv 到 time_t 这样我就可以使用 difftime(a,b)。 struct { int32_t tv_s
struct timeval 和 struct timespec 除了精度不同之外还有什么区别?如果我需要的精度低于 µs(例如,毫秒),我为什么要使用一个而不是另一个? 在我的编译器上(ARM 的
我希望将 timeval 字段附加到我的自定义数据包 header 中。面临类型转换的问题。 标题中我的自定义字段 struct pkthdr { uint64_t sec; uint
我试图查看选择函数监视文件所花费的时间,但是当我尝试打印它时,我得到一个很长的数字。这是代码: struct timeval to; to.tv_usec=25; nfds=select(maxfds
我正在使用 timeval 结构来获取当前系统时间。通常如果我这样声明: timeval curtime; 它正在工作。但是我看到一些代码,人们将其声明为: struct timeval curtim
我有一个 struct timespec我需要转换为 struct timeval 的对象用于 lutimes(...) . 我尝试了以下操作,但是 lutimes()提示。 const struct
我在下面有一个片段 - 我已经以多种方式调整了我的 tv_usec,但是我一直坐在 select() 循环中几乎整整 10 秒,无论tv_usec 的设置。 char buffer[512];
我正在使用 timersub(struct timeval *a, struct timeval *b, struct timeval *res) 来按时进行操作。而我要做的是,用一个较高的值减去一个
我搜索了一些问题 using time.h获得random种子 initialization .特别是在我的例子中,我想放置 time在主函数之外。 根据评论我做了一些修改。在 include as
我在这个程序中有一个错误,我不断地回到这两个函数,但它们对我来说是正确的。这里有什么问题吗? long visual_time_get_msec(VisTime *time_) { visua
我正在测试是否可以使用 gettimeofday() 来衡量一段代码的性能。 #include #include #include int main() { struct timeval *
我正在从 Linux 内核读取(触摸)事件。我想记录这些事件的时间,但我不知道这些事件是作为 timespec 还是 timeval 传递的。谁能指出我正确的方向? 示例代码(从缓冲区读取事件后) s
看完this article关于运行时间,我写了一个简单的代码来计算一个循环的执行时间: #include #include int main (int argc, char** argv) {
我是一名优秀的程序员,十分优秀!