如果在英特尔 CPU 上关闭"SpeedStep Technology",RDTSC() 是否准确?
Is RDTSC() accurate if "SpeedStep Technology" is turned off on a Intel CPU?
寻找最准确的时间戳。
CPU 周期计数器似乎可以提供:使用无符号 __int64 __rdtsc();
如果我能够关闭动态 CPU 速度选项,英特尔芯片上的"SpeedStep 技术"(从我假设的 BIOS 中?
-
rdtsc() 是否是两个之间经过时间的准确度量事件?
-
CPU 时钟速度是多少?是否完全符合广告CPU 速度(即 2.4 GHz CPU - 每秒使用 2,400,000,000 除以 CPU 时钟计数值以获得实际时间)?
rdtsc() 会准确衡量两个事件之间经过的时间吗?
不,不是一般的。如果您将代码限制为在单个处理器/内核上运行,则可能会有一些机会,但如果没有它,计数器与单独处理器/内核之间的差异可能会导致错误的结果。
CPU 时钟速度是多少?它是否正是宣传的 CPU 速度(即 2.4 GHz CPU - 每秒使用 2,400,000,000 除以 CPU 时钟计数值以获得实际时间)?
大多数机器允许用户在 BIOS 设置中调整时钟速度。根据代码运行的环境,您可能可以访问主板的 1.024 MHz 时钟,无论 CPU 时钟速度如何,该时钟都是恒定的。如果你能读懂它,这可以为你确定时间戳计数器上的速率提供坚实的基础。
相关文章:
- 在提升multi_index容器中,是否定义了"default index"?
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 检查输入是否不是整数或数字
- 是否可以初始化不可复制类型的成员变量(或基类)
- 在C++中,是否可以基于给定的标识符创建基类的新实例,反之亦然
- 是否可以通过C++扩展强制多个python进程共享同一内存
- 此代码是否违反一个定义规则
- 是否需要删除包含对象的"pair"?
- 是否可以从int转换为enum类类型
- 无论条件是否为true,if总是在c++中执行
- 如何找到大小'x'数组是否完全填充,在C++?
- 检查值是否在集合p1和p2中,但不在p3中
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 检查 std::shared_ptr<> 的当前底层类型是否为 T
- 在c++中检查长方体是否尽可能快地重叠(无迭代)
- GL_SHADERSTORAGE_BUFFER位置是否与其他着色器位置冲突
- 子目录是否继承属性,例如add_definitions,include_directories和父Cmakelist.t
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在x86_64平台上是否需要 rdtsc 的 mfence?
- 如果在英特尔 CPU 上关闭"SpeedStep Technology",RDTSC() 是否准确?