Question

In C I will do this to convert float representation of number into DWORD. Take the value from the address and cast the content to DWORD.

dwordVal = *(DWORD*)&floatVal;

So for example 44.54321 will become 0x42322C3F.

How can I do the same in C#?

Was it helpful?

Solution

You can use the BitConverter class:

uint value = BitConverter.ToUInt32(BitConverter.GetBytes(44.54321F), 0);
Console.WriteLine("{0:x}", value); // 42322c3f

You could also do this more directly using an unsafe context:

float floatVal = 44.54321F;
uint value;
unsafe { 
    value = *((uint*)(&floatVal));
}
Console.WriteLine("{0:x}", value); // 42322c3f

However, I'd strongly recommend avoiding this. See Should you use pointers (unsafe code) in C#?

OTHER TIPS

Use the BitConverter class:

float f = 44.54321f;
uint u = BitConverter.ToUInt32(BitConverter.GetBytes(f), 0);
System.Diagnostics.Debug.Assert(u == 0x42322C3F);

bitconvert creates a new byte array on every call. this is the solution:

    unsafe public static float ToDecibel(this float x)
    {
        uint* y = (uint*)&x;
        (*y) &= 0x7fffffff;
        return (*y) * 7.17711438e-7f - 764.6161886f;
    }

In .NET Core 2.0 you can use BitConverter.SingleToInt32Bits(). The reverse operation is BitConverter.Int32BitsToSingle()

.NET 6 added 2 more utilities:

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top