首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >128位结构或2 64位记录,用于性能和可实现性。

128位结构或2 64位记录,用于性能和可实现性。
EN

Stack Overflow用户
提问于 2013-09-19 13:35:46
回答 1查看 687关注 0票数 7

我在一个大文件(10秒的GB)中对128位记录进行排序。算法工作良好,目前使用的是uint64_t,其中两条等于一条记录。这是在现代64位系统上。

为了代码的可读性,我想知道是否可以使用像typedef struct u128t {uint64_t hi, uint64_t} u128t这样的结构来代替两个64位的记录。这将使数组索引和分配更加清晰,但我必须实现比较器功能。

这是一个可移植的解决方案吗?我应该期望它以与原始实现相同的速度运行吗?

进一步读:

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-19 13:48:38

使用struct就行了。

我会这样做:

代码语言:javascript
复制
#if COMPILER_WHICH_SUPPORTS_128_BIT_TYPE
    typedef __uint128 u128t;
    #define COMPARE(a, b) ((a) == (b))
#else
    typedef struct {
        uint64_t hi;
        uint64_t lo;
    } u128t;
    #define COMPARE(a, b)   MyCompareFunction((a), (b))
#endif
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18896152

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档