0 is not a power of 2

Andrei Alexandrescu via Digitalmars-d digitalmars-d at puremagic.com
Mon May 18 22:51:26 PDT 2015


On 5/18/15 10:37 PM, H. S. Teoh via Digitalmars-d wrote:
> On Mon, May 18, 2015 at 10:16:47PM -0700, Andrei Alexandrescu via Digitalmars-d wrote:
> [...]
>> bool isPowerOf2(uint x)
>> {
>>      return (x & (x - 1) | !x) == 0;
>> }
> [...]
>
> Are you sure that's correct? Doesn't that return true for all non-zero
> numbers?

Excerpt from std.experimental.allocator.common:

package bool isPowerOf2(uint x)
{
     return (x & (x - 1) | !x) == 0;
}

unittest
{
     assert(!isPowerOf2(0));
     assert(isPowerOf2(1));
     assert(isPowerOf2(2));
     assert(!isPowerOf2(3));
     assert(isPowerOf2(4));
     assert(!isPowerOf2(5));
     assert(!isPowerOf2(6));
     assert(!isPowerOf2(7));
     assert(isPowerOf2(8));
     assert(!isPowerOf2(9));
     assert(!isPowerOf2(10));
}


Andrei



More information about the Digitalmars-d mailing list