c ++位操作如何打印出16位,32位

时间:2013-05-10 10:33:13

标签: c++ bit-manipulation bit

目前我有脚本将数字值打印成位,例如

print((short) 1);

我得到的值为00000001,但我怎样才能获得00000001 00000000这样的值,如果我打印print((int) 1);,我的值为00000001 00000000 00000000 00000000 。 这是我的代码:

void printbyte(unsigned char x)
{
    for (int i = 0; i < 8; i++)
    {
        if (x & 0x80) cout << 1;
        else cout << 0;
        x = x << 1;
    }
    cout << endl;
}

template <typename T>
void print (T A)
{
    unsigned char *p = (unsigned char *) &A;
    printbyte(*p);
}

int main()
{
    print((short) 1);

    system("pause");
    return 0;
}

3 个答案:

答案 0 :(得分:3)

您可以在sizeof(T)中使用print来确定要处理的字节数,然后为每个字节调用printbyte,例如

#include <iostream>
#include <climits>

using namespace std;

void printbyte(unsigned char x)
{
    for (int i = 0; i < CHAR_BIT; i++)
    {
        cout << ((x & 0x80) != 0);
        x <<= 1;
    }
}

template <typename T>
void print (T A)
{    
    for (size_t i = 0; i < sizeof(T); ++i)
    {
        unsigned char b = A >> ((sizeof(T) - i - 1) * CHAR_BIT);
        //unsigned char b = A >> (i * CHAR_BIT); // use this for little endian output
        printbyte(b);
        cout << " ";   
    }
    cout << endl;
}

int main()
{
    print((short) 1);
    print((long long) 42);

    return 0;
}

答案 1 :(得分:0)

你可以使用bitset,这是最简单的方法。这是一个例子:

#include <iostream>
#include <bitset>

using namespace std;

int main ()
{
 int number;
 cin>>number;
 bitset <16> end (number);
 cout<<number<<" --> "<<end<<'\n';
 return 0;
}

或参考:http://www.cplusplus.com/reference/bitset/bitset/

如果您不想使用标准解决方案,它也可能如下所示:

#include <iostream>
#include <climits>
using namespace std;

template <typename Type>
void bprint(Type in)
 {
  unsigned char* p = (reinterpret_cast<unsigned char*>(&in))+(sizeof(Type)-1); //x86
  for(unsigned int n = sizeof(Type);n--;--p, std::cout<<' ')
   for(unsigned int i = CHAR_BIT;i--;)
    std::cout<<((*p&char(1<<i))!=0);
  std::cout<<'\n';
 }

int main(void)
{
 int number;
 cin>>number;
 bprint(number);
 bprint(short(number));
 bprint(char(number));
return 0;
}
如果默认情况下未设置“char *”,则需要

“unsigned”。根据标准,访问变量的内存只有一个变量类型或无符号字符的指针。

最有趣的选择是使用数学,尤其是Gynvael Coldwind所描述的,http://gynvael.coldwind.pl/n/c_cpp_number_to_binary_string_01011010

答案 2 :(得分:0)

我认为你应该使用std::bitset,但是你必须在编译时指定大小。 为避免这种情况,您可以使用这样的模板函数(请注意,这是C ++ 11):

#include <iostream>
#include <bitset>
#include <limits>

template <class T> void PrintBits (const T &Number) {
    std::bitset<std::numeric_limits<T>::digits> Bit_Number(Number);
    std::cout << Bit_Number << std::endl;

}