我正在尝试在程序集中编写一个函数(但我们假设语言与该问题无关)。
如何使用按位运算符将传入的数字的所有位设置为1?
我知道我可以使用带有我希望设置的位的掩码的“或”,但我不知道如何根据N大小的二进制数构造掩码。
〜(x&0)
x&0将始终为0,并且〜将所有位翻转为1。
将其设置为0,然后使用按位NOT将所有位翻转为1。
你会发现用汇编语言你必须知道“传入的数字”的大小。在汇编语言中,汇编语言适用于哪台机器真的很重要。
鉴于这些信息,您可能会问
要么
要填充所有1位的寄存器,在大多数机器上,有效的方法需要两条指令:
用1位填充内存则需要1个或更多存储指令......
你会在Hank Warren的精彩书籍Hacker's Delight中找到更多有点蠢蠢欲动的提示和技巧。
将x设置为1
而x <number x = x * 2
答案=数字或x - 1。
代码假定您的输入称为“数字”。它应该适用于正值。注意负值是两次补充操作尝试没有意义,因为高位将始终为1。
将它设置为-1
。这通常由所有位为1表示。
使用T(~T(0))
。
其中T
是typename(如果我们谈论的是C ++。)
如果类型小于int
,这可以防止不必要的促销到int
。