Coming from a discussion started here, does the standard specify values for characters? So, is '0' guaranteed to be 48? That’s what ASCII would tell us, but is it guaranteed? If not, have you seen any compiler where '0' isn’t 48?
Coming from a discussion started here , does the standard specify values for characters?
Share
No. There’s no requirement for the either the source or execution character sets to use an encoding with an ASCII subset. I haven’t seen any non-ASCII implementations but I know someone who knows someone who has. (It is required that ‘0’ – ‘9’ have contiguous integer values, but that’s a duplicate question somewhere else on SO.)
The encoding used for the source character set controls how the bytes of your source code are interpreted into the characters used in the C++ language. The standard describes the members of the execution character set as having values. It is the encoding that maps these characters to their corresponding values the determines the integer value of
'0'.Although at least all of the members of the basic source character set plus some control characters and a null character with value zero must be present (with appropriate values) in the execution character set, there is no requirement for the encoding to be ASCII or to use ASCII values for any particular subset of characters (other than the null character).