Register FAQ / Rules Forum Spy Search Today's Posts Mark Forums Read
 MacRumors Forums Silly Signed / Unsigned question

 Jan 4, 2013, 05:49 PM #1 larswik macrumors 65816   Join Date: Sep 2006 Silly Signed / Unsigned question I know the difference between Signed and Unsigned but I was curious why they call them that? I did google for the answer but the response I find explain what the difference are and not what the terminology is so I thought I would ask real quick instead? My guess is unsigned, being only positive numbers, means there is no minus SIGN in front of it but that is only guess. Just wondering? __________________ I know more than yesterday. Lars 0
 Jan 4, 2013, 05:53 PM #2 mobilehaathi macrumors 68030     Join Date: Aug 2008 Location: Bay Area, CA Unsigned integers don't store any information about the sign of the number. __________________ Of crimes---none is greater than having things that one desires; Of disasters---none is greater than not knowing when one has enough. Of defects---none brings more sorrow than the desire to attain. 0
Jan 4, 2013, 06:27 PM   #3
larswik
macrumors 65816

Join Date: Sep 2006
Quote:
 Originally Posted by mobilehaathi Unsigned integers don't store any information about the sign of the number.
And the sign being the minus sign? So it just stores the numbers, that's it and that is why it is called unsigned and signed because of that minus sign.

So it is what I thought. Thanks for confirming it.
__________________
I know more than yesterday.
Lars
0
Jan 4, 2013, 06:34 PM   #4
subsonix
macrumors 68000

Join Date: Feb 2008
Quote:
 Originally Posted by larswik My guess is unsigned, being only positive numbers, means there is no minus SIGN in front of it but that is only guess. Just wondering?
The most significant bit in a signed integer indicates if the number is negative or not, this is the sign bit. You can verify this by trying to assign (1 << 31) to a signed integer which will set the bit and result in a negative number. A signed integer have the same range but half of it is used for negative values. For more information look up two's complement to see how they are represented on modern hardware.
0
 Jan 4, 2013, 06:34 PM #5 ArtOfWarfare macrumors 68040     Join Date: Nov 2007 If a number is signed, the first bit is the sign bit. A sign bit of 0 corresponds to a + sign and a sign bit of 1 corresponds to a - sign. With unsigned numbers, there's no bit that holds the sign information. 0
 Jan 4, 2013, 06:35 PM #6 mobilehaathi macrumors 68030     Join Date: Aug 2008 Location: Bay Area, CA Sign being a property of a number, either positive or negative. __________________ Of crimes---none is greater than having things that one desires; Of disasters---none is greater than not knowing when one has enough. Of defects---none brings more sorrow than the desire to attain. 0
 Jan 4, 2013, 07:23 PM #7 Doctor Q macrumors god     Join Date: Sep 2002 Location: Blood Donation Center Here's an example, which assumes (since it's always true for Mac programming) that we're using the two's complement method for storing signed numbers. We're pretend we have only 4 bits in our integers: How the 16 possible unsigned bit patterns are interpreted:0000 means 0 0001 means 1 (which is the same as +1) 0010 means 2 (which is the same as +2) 0011 means 3 (which is the same as +3) 0100 means 4 (which is the same as +4) 0101 means 5 (which is the same as +5) 0110 means 6 (which is the same as +6) 0111 means 7 (which is the same as +7) 1000 means 8 (which is the same as +8) 1001 means 9 (which is the same as +9) 1010 means 10 (which is the same as +10) 1011 means 11 (which is the same as +11) 1100 means 12 (which is the same as +12) 1101 means 13 (which is the same as +13) 1110 means 14 (which is the same as +14) 1111 means 15 (which is the same as +15) Conclusion: We can represent 16 different integers but all of them are positive. How the 16 possible signed bit patterns are interpreted:0000 means 0 0001 means 1 (which is the same as +1) 0010 means 2 (which is the same as +2) 0011 means 3 (which is the same as +3) 0100 means 4 (which is the same as +4) 0101 means 5 (which is the same as +5) 0110 means 6 (which is the same as +6) 0111 means 7 (which is the same as +7) 1000 means -8 1001 means -7 1010 means -6 1011 means -5 1100 means -4 1101 means -3 1110 means -2 1111 means -1 Conclusion: We can represent 8 different non-negative integers and 8 different negative integers.Notice that the unsigned bit patterns don't really represent unsigned numbers. Each bit pattern in both sets represents an integer, and integers by nature always have a sign. People tend to gloss over the distinction. __________________ I support the MacRumors Blood Drive! 0
Jan 4, 2013, 08:10 PM   #8
larswik
macrumors 65816

Join Date: Sep 2006
Quote:
 Originally Posted by Doctor Q Here's an example, which assumes (since it's always true for Mac programming) that we're using the two's complement method for storing signed numbers. We're pretend we have only 4 bits in our integers: How the 16 possible unsigned bit patterns are interpreted:0000 means 0 0001 means 1 (which is the same as +1) 0010 means 2 (which is the same as +2) 0011 means 3 (which is the same as +3) 0100 means 4 (which is the same as +4) 0101 means 5 (which is the same as +5) 0110 means 6 (which is the same as +6) 0111 means 7 (which is the same as +7) 1000 means 8 (which is the same as +8) 1001 means 9 (which is the same as +9) 1010 means 10 (which is the same as +10) 1011 means 11 (which is the same as +11) 1100 means 12 (which is the same as +12) 1101 means 13 (which is the same as +13) 1110 means 14 (which is the same as +14) 1111 means 15 (which is the same as +15) Conclusion: We can represent 16 different integers but all of them are positive. How the 16 possible signed bit patterns are interpreted:0000 means 0 0001 means 1 (which is the same as +1) 0010 means 2 (which is the same as +2) 0011 means 3 (which is the same as +3) 0100 means 4 (which is the same as +4) 0101 means 5 (which is the same as +5) 0110 means 6 (which is the same as +6) 0111 means 7 (which is the same as +7) 1000 means -8 1001 means -7 1010 means -6 1011 means -5 1100 means -4 1101 means -3 1110 means -2 1111 means -1 Conclusion: We can represent 8 different non-negative integers and 8 different negative integers.Notice that the unsigned bit patterns don't really represent unsigned numbers. Each bit pattern in both sets represents an integer, and integers by nature always have a sign. People tend to gloss over the distinction.
There was more involved then I thought. This makes it totally clear what is happening.

Thanks guys. I can remember my teacher covering that in my Pascal class a couple years back.
__________________
I know more than yesterday.
Lars
0
 Jan 5, 2013, 01:39 PM #9 Sydde macrumors 68000     Join Date: Aug 2009 The simple mathematical logic of signed numbers is:if a + b = 0 then a = -b and b = -aIf you assign a negative number to an int, then assign the value of that int to an unsigned int, you end up with an integer value that is very large, because all the assignment does is copy the bits over to the other field. If you then reverse the assignment, you get the negative number back. If you assign a negative number to a SInt64 (signed 64 bit value), then assign that to a UInt32 (unsigned 32 bit value), then reverse the assignment, the 64 will have the same value as the unsigned 32. This could be important to know in certain circumstances, but most of the time it will not affect program behavior (because most of the time, you will not do stuff like this). __________________ Mr. Paul, sir, I thought you should be advised, there seems to be a zombie tribble clinging to your head, for it is scarfing your brain 0

 MacRumors Forums

 Posting Rules You may not post new threads You may not post replies You may not post attachments You may not edit your posts BB code is On Smilies are On [IMG] code is On HTML code is Off Forum Rules