View source code
							
							
						
								Display the source code in std/math/traits.d from which thispage was generated on github.
							
						
							Report a bug
							
						
								If you spot a problem with this page, click here to create aBugzilla issue.
							
						
							
								Improve this page
							
							
					
								Quickly fork, edit online, and submit a pull request for this page.Requires a signed-in GitHub account. This works well for small changes.If you'd like to make larger changes you may want to consider usinglocal clone.
							
						Function std.math.traits.isPowerOf2
Check whether a number is an integer power of two.
						
				bool isPowerOf2(X)(
				
  const X x
				
				) pure nothrow @nogc @safe
				
				if (isNumeric!X);
						
					
				Note that only positive numbers can be integer powers of two. This
function always return false if x is negative or zero.
Parameters
| Name | Description | 
|---|---|
| x | the number to test | 
Returns
true if x is an integer power of two.
Example
import stdExample
assert( isPowerOf2(1));
assert( isPowerOf2(2));
assert( isPowerOf2(1uL << 63));
assert(!isPowerOf2(-4));
assert(!isPowerOf2(0));
assert(!isPowerOf2(1337u));
Authors
Walter Bright, Don Clugston, Conversion of CEPHES math library to D by Iain Buclaw and David Nadlinger
License
					Copyright © 1999-2025 by the D Language Foundation | Page generated by ddox.