首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >优化"i =b?(i | mask):(i & ~mask)“

优化"i =b?(i | mask):(i & ~mask)“
EN

Stack Overflow用户
提问于 2016-11-16 18:34:38
回答 4查看 156关注 0票数 4

我希望能够设置或清除uintX_t t的(多个)位。

i是一个运行时变量(uintX_t)。b是一个运行时变量(uintX_t),它被约束为01

mask是一个编译时常量。

还有比这更好的方法吗:

代码语言:javascript
复制
i = b ? (i | mask) : (i & ~mask)

如果可能的话,我希望避免分支。目标是ARM,如果重要的话。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2016-11-16 19:05:21

另一种选择是:始终将位设置为0(左侧部分),并可选择将位设置为1(右侧部分)。

代码语言:javascript
复制
i = (i & ~mask) | (mask * b);
票数 5
EN

Stack Overflow用户

发布于 2016-11-16 19:36:18

利用-1u是设置了所有位的值这一事实:

代码语言:javascript
复制
i = (i & ~mask) | (mask & -b);

或者

代码语言:javascript
复制
i ^= (i ^ -b) & mask;

第二种方法减少了操作的数量和代码大小。第一种方法在超标量架构上可能仍然更快,因为一些操作可以并行执行。

票数 6
EN

Stack Overflow用户

发布于 2016-11-16 18:55:16

这里的想法是用乘法代替分支,我们可以根据b的值将每一条边归零:

代码语言:javascript
复制
i = (i | (mask * b)) & (~mask | (mask * b));
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40629878

复制
相关文章

相似问题

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