digitalmars.D.learn - wrong struct alignment
- dd0s (17/17) Jul 01 2015 i have the following struct, and i expect it to have 30 bytes
- Adam D. Ruppe (16/18) Jul 01 2015 That's expected because scope_id takes 4 bytes, so port has to be
- anonymous (12/29) Jul 01 2015 Disclaimer: My understanding of all things alignment is limited.
- dd0s (1/1) Jul 01 2015 thank you both, indeed missed that truncation step
i have the following struct, and i expect it to have 30 bytes but sizeof tells me it has 32 bytes. dmd seems to still use 4byte alignment altough i specified to align 2bytes. struct netadr_t { align(2): int type; // 0 int scope_id; // 4 short port; // 8 // <-- this is 4 bytes instead of 2 int sock; // 10 union { ubyte[4] ip; // 14 ubyte[10] ipx; ubyte[16] ip6; } } since i'm interfacing with a c library the struct layout has to be equal :(
Jul 01 2015
On Wednesday, 1 July 2015 at 20:01:08 UTC, dd0s wrote:int scope_id; // 4 short port; // 8 // <-- this is 4 bytes instead of 2That's expected because scope_id takes 4 bytes, so port has to be at 8 so it doesn't overlap the preceding int. The extra two bytes you see in sizeof are probably at the *end* of the struct, not between the members. To get rid of them, out align(2) on the outside too: align(2) struct yourthing { align(2): members } That will trim the size. The align inside the struct packs the members, but still pads the end (which means an array of these structs will be aligned on the word boundary). The align on the outside removes the padding at the end, meaning an an array of the structs would be packed too.
Jul 01 2015
On Wednesday, 1 July 2015 at 20:01:08 UTC, dd0s wrote:i have the following struct, and i expect it to have 30 bytes but sizeof tells me it has 32 bytes. dmd seems to still use 4byte alignment altough i specified to align 2bytes. struct netadr_t { align(2): int type; // 0 int scope_id; // 4 short port; // 8 // <-- this is 4 bytes instead of 2 int sock; // 10 union { ubyte[4] ip; // 14 ubyte[10] ipx; ubyte[16] ip6; } } since i'm interfacing with a c library the struct layout has to be equal :(Disclaimer: My understanding of all things alignment is limited. `pragma(msg, netadr_t.sock.offsetof);` prints "10LU", so port seems to really only take 2 bytes. The struct itself has padding at the end. You can eliminate that with an `align(1)` on the struct: ---- align(1) struct netadr_t { align(2): ... } ----
Jul 01 2015