Question

What is the best way to combine two uints into a ulong in c#, setting the high/low uints.

I know bitshifting can do it, but I don't know the syntax, or there maybe other APIs to help like BitConverter, but I don't see a method that does what I want.

Was it helpful?

Solution

ulong mixed = (ulong)high << 32 | low;

The cast is very important. If you omit the cast, considering the fact that high is of type uint (which is 32 bits), you'll be shifting a 32 bit value 32 bits to the left. Shift operators on 32 bit variables will use shift stuff by right-hand-side mod 32. Effectively, shifting a uint 32 bits to the left is a no-op. Casting to ulong prevents this.

Verifying this fact is easy:

uint test = 1u;
Console.WriteLine(test << 32); // prints 1
Console.WriteLine((ulong)test << 32); // prints (ulong)uint.MaxValue + 1

OTHER TIPS

ulong output = (ulong)highUInt << 32 + lowUInt

The << and >> operators bitshift to the left (higher) and right (lower), respectively. highUInt << 32 is functionally the same as highUInt * Math.Pow(2, 32), but may be faster and is (IMO) simpler syntax.

You have to convert the highInt to a ulong before you bitshift:

ulong output = highInt;
output = output << 32;
output += lowInt;

Encoding:

ulong mixed = (ulong)hi << 32 | lo;

Decoding:

uint lo = (uint)(mixed & uint.MaxValue);
uint hi = (uint)(mixed >> 32);
Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top