加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 纳秒到毫秒 – 快速划分1000000

发布时间:2020-12-16 06:01:36 所属栏目:百科 来源:网络整理
导读:我想将输出从gethrtime转换为毫秒. 明显的做法是除以1000000. 不过,我经常这样做,想知道是否会成为瓶颈. 处理像1000000这样的数字时,是否有优化的分割操作? 注意:任何代码必须可移植.我使用gcc,这通常是在Sparc硬件上 一些使用以下代码的快速测试…希望是
我想将输出从gethrtime转换为毫秒.

明显的做法是除以1000000.
不过,我经常这样做,想知道是否会成为瓶颈.

处理像1000000这样的数字时,是否有优化的分割操作?

注意:任何代码必须可移植.我使用gcc,这通常是在Sparc硬件上

一些使用以下代码的快速测试…希望是对的.

#include <sys/time.h>
#include <iostream>

using namespace std;

const double NANOSECONDS_TO_MILLISECONDS = 1.0 / 1000000.0;

int main()
{
    hrtime_t start;
    hrtime_t tmp;
    hrtime_t fin;

    start = gethrtime();
    tmp = (hrtime_t)(start * NANOSECONDS_TO_MILLISECONDS);
    fin = gethrtime();

    cout << "Method 1"
    cout << "Original val: " << start << endl;
    cout << "Computed: " << tmp << endl;
    cout << "Time:" << fin - start << endl;

    start = gethrtime();
    tmp = (start / 1000000);
    fin = gethrtime();

    cout "Method 2"    
    cout << "Original val: " << start << endl;
    cout << "Computed: " << tmp << endl;
    cout << "Time:" << fin - start << endl;

    return 0;
}

示例输出:

Original val: 3048161553965997
Computed: 3048161553
Time:82082
Original val: 3048161556359586
Computed: 3048161556
Time:31230

Original val: 3048239663018915
Computed: 3048239663
Time:79381
Original val: 3048239665393873
Computed: 3048239665
Time:31321

Original val: 3048249874282285
Computed: 3048249874
Time:81812
Original val: 3048249876664084
Computed: 3048249876
Time:34830

如果这是正确的,那么在这种情况下,乘以倒数实际上更慢.这可能是由于使用浮点数学而不是固定点数学.我只会坚持整数除法,根本不需要任何时间.

解决方法

部门不是一个昂贵的操作.如果您的应用程序的主要瓶颈是一个1000000分钟的操作,我非常怀疑.浮点处理器的速度比任何类型的“技巧”要快,而不仅仅是单次操作.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读