View more

View more

View more

### Image of the Day Submit

IOTD | Top Screenshots

### The latest, straight to your Inbox.

Subscribe to GameDev.net Direct to receive the latest updates and exclusive content.

# What IS a DWORD?

Old topic!

Guest, the last post of this topic is over 60 days old and at this point you may not reply in this topic. If you wish to continue this conversation start a new topic.

10 replies to this topic

### #1Draxis  Members

Posted 17 February 2002 - 11:54 AM

Yeah, I''m sure it''s a newb question, but what exactly IS a DWORD? I know it''s some sort of crazy MS typedef, but other than that, I dunno. I looked it up on MSDN but only got it''s general usage, not exactly what it is and what makes it up.

### #2Anonymous Poster_Anonymous Poster_*  Guests

Posted 17 February 2002 - 11:56 AM

32 bit unsigned integer

### #3matrix2113  Members

Posted 17 February 2002 - 12:02 PM

bit = ...1 bit...
nybble = 4 bits = 1/2 byte
byte = 8 bits = 2 nybbles
WORD = 2 bytes = 4 nybbles = 16 bits
DWORD = 2 WORDs = 4 bytes = 8 nybbles = 32 bits
QWORD = 2 DWORDs = 4 WORDS = ..... = 64 bits
There might be more; if there are, I don't know of them.

EDIT: DWORD stands for Double Word, QWORD for Quad (prefix meaning 4). I suppose the next would be Oct (prefix meaning 8).

"I've learned something today: It doesn't matter if you're white, or if you're black...the only color that REALLY matters is green"
-Peter Griffin

Edited by - matrix2113 on February 17, 2002 7:04:27 PM

### #4Draxis  Members

Posted 17 February 2002 - 12:19 PM

Thankya!
But here''s question 2.
How can DWORDs take statements like:
  DWORD dwBlah;dwBlah = STATEMENT1 | STATEMENT2 | STATEMENT3;

What''s with the pipes and the multiple option thing?
How exactly does the compiler interpret that?

### #5Arild Fines  Members

Posted 17 February 2002 - 12:52 PM

Its a binary OR operation. Eg - 0 OR 0 = 0, 0 OR 1 = 1, 1 OR 0 = 1 and 1 OR 1 = 1.
In cases like your example its usually used to implement flags. You can then check for whether a flag is set like this:
  if ( dwBlah & aFlag != 0 ) doSomething();

### #6Draxis  Members

Posted 17 February 2002 - 01:09 PM

Ok, now, what are the flags?
They obviously have to hold some value (0 or 1?).
How exactly is that assigned?

### #7explodingrabbit  Members

Posted 17 February 2002 - 01:32 PM

Each flag has a different bit set. A DWORD is 8 bits long therefore there are a maximum of 8 different flags that can be used.

eg.

Flag1 = 00000001
Flag2 = 00000010
Flag3 = 00000100
Flag4 = 00001000

and so on

therefore if dwSomething = Flag1 | Flag2 | Flag3
then dwSomething = 00000001 | 00000010 | 00000100
= 00000111.

### #8explodingrabbit  Members

Posted 17 February 2002 - 01:36 PM

Sorry, my brain wasn''t working today - A DWORD is 32 bits long therefore there is a maximum of 32 possible flags.

### #9Colin Jeanne  Members

Posted 17 February 2002 - 01:39 PM

A flag is a value that a function looks at to determine what it should be doing. Arild Fines showed how a function checks to see if a flag is set in the function.

Flags are defined by whoever writes the function, usually they are assigned powers of two because when you OR them together powers of two wont affect each other.

For example, if we defined some flags with decimal values

EX_1 = 1; //00000001 in binary
EX_2 = 2; //00000010 in binary
EX_3 = 4; //00000100 in binary
EX_4 = 8; //00001000 in binary

When we OR them together their values will be superimposed.

EX_1 | EX_2 will be 3, or 00000011 in binary
EX_8 | EX_4 | EX_1 will be 13, or 00001101 in binary

Extracting a specific flag from a dword uses the AND (&) operator. For AND, both bits must be 1 to return 1 or it will return 0.

Suppose you have value 00001101 and you want to see if the flag EX_2 is in it, using 00001101 AND EX_2 would return 0 (flag EX_2 is not included) because

00001101
& 00000010
----------
00000000

00001101 AND EX_8 will return EX_8 (the flag is included) because

00001101
& 00001000
----------
00001000

by the way, I''ve been using single bytes to explain the use of flags and AND and OR so that you could see the individual 0''s and 1''s without me having to type out 32 of them out to represent a double word. I''m sure you already figured that though

### #10merlin9x9  Members

Posted 17 February 2002 - 01:58 PM

DWORD is a typedef from the Windows API. Most such typedefs are anachronisms. For example, a WORD is 16 bits and a DWORD is 32 bits (as has been said), but those names are currently misnomers. You see, a "word" refers the the addressing size of the target processor. When the Windows API was first devised, a word was 16 bits, hence the 16-bit size for the WORD type. But most processors these days address 32 bits at a time, so they have 32-bit words. For backwards compatibility, WORD stayed the same, even though—from the name—it should be 32-bits. Other types like LPARAM and WPARAM have become the same size (32 bits), even though WPARAM used to be 16-bits as is indicated by the W prefix (which stands for WORD). So, it''s confusing, especially since Intel parlence has followed the same trend of backwards compatibility with naming. But don''t forget what a real word is—that it''s dependent on the processor.

### #11Draxis  Members

Posted 17 February 2002 - 02:27 PM

Thankyou everyone, I get it now
Sorry about the multitude of questions though.
I just like to understand something inside out and it drives me nuts when I don''t.

Old topic!

Guest, the last post of this topic is over 60 days old and at this point you may not reply in this topic. If you wish to continue this conversation start a new topic.