View source code
Display the source code in core/bitop.d from which this
page was generated on github.
Report a bug
If you spot a problem with this page, click here to create a
Bugzilla 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 using
local clone.
Struct core.bitop.BitRange
Range over bit set. Each element is the bit number that is set.
struct BitRange
;
This is more efficient than testing each bit in a sparsely populated bit set. Note that the first bit in the bit set would be bit 0.
Constructors
Name | Description |
---|---|
this
(bitarr, numBits)
|
Construct a BitRange. |
Methods
Name | Description |
---|---|
empty
()
|
Range functions |
front
()
|
Range functions |
popFront
()
|
Range functions |
Example
import core .stdc .stdlib : malloc, free;
import core .stdc .string : memset;
// initialize a bit array
enum nBytes = (100 + BitRange .bitsPerWord - 1) / 8;
size_t *bitArr = cast(size_t *)malloc(nBytes);
scope(exit) free(bitArr);
memset(bitArr, 0, nBytes);
// set some bits
bts(bitArr, 48);
bts(bitArr, 24);
bts(bitArr, 95);
bts(bitArr, 78);
enum sum = 48 + 24 + 95 + 78;
// iterate
size_t testSum;
size_t nBits;
foreach (b; BitRange(bitArr, 100))
{
testSum += b;
++nBits;
}
writeln(testSum); // sum
writeln(nBits); // 4
Authors
Don Clugston, Sean Kelly, Walter Bright, Alex Rønne Petersen, Thomas Stuart Bockman
License
Copyright © 1999-2022 by the D Language Foundation | Page generated by ddox.