Search code examples
c++cbinary

Can I use a binary literal in C or C++?


I need to work with a binary number.

I tried writing:

const char x = 00010000;

But it didn't work.

I know that I can use a hexadecimal number that has the same value as 00010000, but I want to know if there is a type in C++ for binary numbers, and if there isn't, is there another solution for my problem?


Solution

  • You can use BOOST_BINARY while waiting for C++0x. :) BOOST_BINARY arguably has an advantage over template implementation insofar as it can be used in C programs as well (it is 100% preprocessor-driven.)

    To do the converse (i.e. print out a number in binary form), you can use the non-portable itoa function, or implement your own.

    Unfortunately you cannot do base 2 formatting with STL streams (since setbase will only honour bases 8, 10 and 16), but you can use either a std::string version of itoa, or (the more concise, yet marginally less efficient) std::bitset.

    #include <boost/utility/binary.hpp>
    #include <stdio.h>
    #include <stdlib.h>
    #include <bitset>
    #include <iostream>
    #include <iomanip>
    
    using namespace std;
    
    int main() {
      unsigned short b = BOOST_BINARY( 10010 );
      char buf[sizeof(b)*8+1];
      printf("hex: %04x, dec: %u, oct: %06o, bin: %16s\n", b, b, b, itoa(b, buf, 2));
      cout << setfill('0') <<
        "hex: " << hex << setw(4) << b << ", " <<
        "dec: " << dec << b << ", " <<
        "oct: " << oct << setw(6) << b << ", " <<
        "bin: " << bitset< 16 >(b) << endl;
      return 0;
    }
    

    produces:

    hex: 0012, dec: 18, oct: 000022, bin:            10010
    hex: 0012, dec: 18, oct: 000022, bin: 0000000000010010
    

    Also read Herb Sutter's The String Formatters of Manor Farm for an interesting discussion.