I was looking at hash functions the other day and came across a website that had an example of one. Most of the code was easy to grasp, however this macro function I can’t really wrap my head around.
Could someone breakdown what’s going on here?
#define get16bits(d) ((((uint32_t)(((const uint8_t *)(d))[1])) << 8) +(uint32_t)(((const uint8_t *)(d))[0]))
Basically it gets the lower 16 bit of the 32 bit integer d
lets break it down
first we must pass the address of a to
get16bits()or it will not work.this first converts the 32 bit integer into an array of 8 bit integers and retrieves the 2 one.
It then shifts the value by 8 bit so it and adds the lower 8 bits to it
In our example it will be