delorie.com/archives/browse.cgi | search |
From: | gk_2345 AT my-deja DOT com |
Newsgroups: | comp.os.msdos.djgpp |
Subject: | Re: structure size rounded to int size? |
Date: | Thu, 21 Oct 1999 20:21:48 GMT |
Organization: | Deja.com - Before you buy. |
Lines: | 39 |
Message-ID: | <7unsko$j91$1@nnrp1.deja.com> |
References: | <380F12E1 DOT 74D9DE4 AT umh DOT ac DOT be> |
NNTP-Posting-Host: | 209.138.153.30 |
X-Article-Creation-Date: | Thu Oct 21 20:21:48 1999 GMT |
X-Http-User-Agent: | Mozilla/4.0 (compatible; MSIE 4.01; Windows 98) |
X-Http-Proxy: | 1.0 x41.deja.com:80 (Squid/1.1.22) for client 209.138.153.30 |
X-MyDeja-Info: | XMYDJUIDgk_2345 |
To: | djgpp AT delorie DOT com |
DJ-Gateway: | from newsgroup comp.os.msdos.djgpp |
Reply-To: | djgpp AT delorie DOT com |
In article <380F12E1 DOT 74D9DE4 AT umh DOT ac DOT be>, Fabrice LETE <et980139 AT umh DOT ac DOT be> wrote: > If I have: > > typedef struct FOO { > short a; long b; > }; > > sizeof(FOO) give me 8... > > What can I do to avoid the problem (I guess it's a switch to use with > the compiler...)? errrr... sort of. There are macros you can embed in the struct definition to get around this. The 'problem' is that gcc by default aligns the members of structs along whatever alignment boundaries are handy for a given CPU. This means that the beginning of b isn't always the byte immediately following the end of a. re-write the above as: typedef struct FOO { short a __attribute__((packed)); long b __attribute__((packed)); }; and FOO will now be 6 bytes long. Consult the gcc docs, and DJGPP FAQ for more details. NOTE: packed struct take longer to access than aligned structs, so only do this if there is actually a reason to. Good luck. Sent via Deja.com http://www.deja.com/ Before you buy.
webmaster | delorie software privacy |
Copyright © 2019 by DJ Delorie | Updated Jul 2019 |