|
1
3
函数调用没有优化,而是重新排序。其编译方式如下:
这种重新排序是合法的,因为_sleep和timestamp都不构成IO。如果您支持c++11,可以使用信号处理程序内存围栏来防止这种重新排序。只需包括并插入:
在析构函数和构造函数体的开头。x86_&4,这样的内存围栏不会产生任何代码,只会限制编译器重新排序。 |
![]() |
2
2
我认为C++优化器实际上不是问题所在。更可能的是,问题是,在某些情况下,您尝试测量的时间量小于您使用的时钟的最小粒度——也就是说,timestamp()在TimeSlice构造函数和析构函数中都返回相同的值,因为第二次调用在第一次调用之后执行得如此之快,以至于时钟值没有足够的时间来增加其下一个刻度量。 如果是这种情况,那么解决方案将是要么找到一个更高精度的时钟API来代替,要么测量更长的事件(例如,对操作进行10000次迭代并测量),要么只是理解非常小的时间增量可能会被时钟的滴答粒度有效地四舍五入到零。 |
![]() |
apetrai · 我应该如何假设算法使用哪种迭代器类别? 2 年前 |
![]() |
ridiculous_fish · std::是否保证短路? 2 年前 |
![]() |
Fabio · 在c中将指针赋给常数指针++ 2 年前 |
![]() |
johnco3 · 初始化固定C数组成员结构 7 年前 |
![]() |
mans · 为什么出现此错误:constexpr在此处无效 7 年前 |
![]() |
juztcode · 在C++中尝试捕获-创建了多少个对象 7 年前 |
![]() |
Steven Scott · 忽略元素的基于范围的for循环 7 年前 |