All the time I read sentences like
don’t rely on 1 byte being 8 bit in size
use
CHAR_BITinstead of 8 as a constant to convert between bits and bytes
et cetera. What real life systems are there today, where this holds true?
(I’m not sure if there are differences between C and C++ regarding this, or if it’s actually language agnostic. Please retag if neccessary.)
On older machines, codes smaller than 8 bits were fairly common, but most of those have been dead and gone for years now.
C and C++ have mandated a minimum of 8 bits for
char, at least as far back as the C89 standard. [Edit: For example, C90, §5.2.4.2.1 requiresCHAR_BIT>= 8 andUCHAR_MAX>= 255. C89 uses a different section number (I believe that would be §2.2.4.2.1) but identical content]. They treat “char” and “byte” as essentially synonymous [Edit: for example,CHAR_BITis described as: “number of bits for the smallest object that is not a bitfield (byte)”.]There are, however, current machines (mostly DSPs) where the smallest type is larger than 8 bits — a minimum of 12, 14, or even 16 bits is fairly common. Windows CE does roughly the same: its smallest type (at least with Microsoft’s compiler) is 16 bits. They do not, however, treat a
charas 16 bits — instead they take the (non-conforming) approach of simply not supporting a type namedcharat all.