问题:如何将一个数值如0xfaceabcd转化成二进制的字符串?
第一时间想到的是STL
对了就是bitset对象
详细见http://www.cplusplus.com/reference/bitset/bitset/?kw=bitset
#include <iostream> #include <bitset> using namespace std; int main() { bitset<32> t(0xfaceabcd); cout<<"0x"<<hex<<t.to_ulong()<<"="<<t.to_string()<<"b"<<endl; }输出:0xfaceabcd=11111010110011101010101111001101b
#include <windows.h> #include <tchar.h> template <typename T> class XBIT { private: UINT m_size;//位数 T m_value;//值 TCHAR *m_szBuf;//二进制字符串,用new动态创建,destroy()中消除 public: XBIT(T value=0) { m_size=sizeof(T)*8; m_value=value; m_szBuf=new TCHAR[m_size+1];//+1 for NULL terminal to_string(); } ~XBIT() { destroy(); } void destroy() { if( NULL!=m_szBuf ) { delete[] m_szBuf; m_szBuf=NULL; } } T getvalue() { return m_value; } void setvalue(T value) { m_value=value; to_string(); } TCHAR *getstr() { return m_szBuf; } TCHAR *to_string() { memset(m_szBuf,'x',m_size+1); m_szBuf[m_size]=TEXT('\0'); for(int n=m_size-1;n>=0;n--)//方法一 { TCHAR ch=(m_value>>n)&0x1 ?TEXT('1'):TEXT('0'); m_szBuf[m_size-1-n]=ch; } //for(int n=0;n<m_size;n++)//方法二 //{ //TCHAR ch=( m_value>>(m_size-1-n) )&0x1 ?TEXT('1'):TEXT('0'); //m_szBuf[n]=ch; //printf("[d%02d]=%c\t",n,ch); //} return m_szBuf; } };
下面是测试
int _tmain() { XBIT<long> f(0xfaceabcd); _tprintf(_T("0x%x=%sb"),f.getvalue(),f.to_string()); }结果
#ifndef UNICODE #define UNICODE #endif #ifndef _UNICODE #define _UNICODE #endif #include <windows.h> #include <tchar.h> template <typename T> class XBIT { private: UINT m_size;//位数 T m_value;//值 TCHAR *m_szBuf;//二进制字符串,用new动态创建,destroy()中消除 public: XBIT(T value=0) { m_size=sizeof(T)*8; m_value=value; m_szBuf=new TCHAR[m_size+1];//+1 for NULL terminal to_string(); } ~XBIT() { destroy(); } T getvalue() { return m_value; } void setvalue(T value)//每次改变均调用私有参数to_string() { m_value=value; to_string(); } TCHAR *getstring() { return m_szBuf; } private: void destroy() { if( NULL!=m_szBuf ) { delete[] m_szBuf; m_szBuf=NULL; } } TCHAR *to_string() { memset(m_szBuf,0,m_size+1); m_szBuf[m_size]=TEXT('\0'); for(int n=m_size-1;n>=0;n--)//方法一 { TCHAR ch=(m_value>>n)&0x1 ?TEXT('1'):TEXT('0'); m_szBuf[m_size-1-n]=ch; } //for(int n=0;n<m_size;n++)//方法二 //{ //TCHAR ch=( m_value>>(m_size-1-n) )&0x1 ?TEXT('1'):TEXT('0'); //m_szBuf[n]=ch; //printf("[d%02d]=%c\t",n,ch); //} return m_szBuf; } }; int _tmain() { XBIT<unsigned long long> f(0xabcdef0123456789); _tprintf(_T("0x%x=%sb"),f.getvalue(),f.getstring()); }
然后弹出错误窗口
哪里错了?
tt.exe 中的 0x00402532 处未处理的异常: 0xC0000005: 读取位置 0xabcdef01 时发生访问冲突
原来是这个_tprintf(_T("0x%x=%sb"),f.getvalue(),f.getstring());
看到了吗
sizeof(unsigned long long) =8字节
原来%x格式化输出也不是万能的,我们要把 %x 改成 %I64x,或者 %llx
即
_tprintf(_T("0x%I64x=%sb"),f.getvalue(),f.getstring());
或
_tprintf(_T("0x%llx=%sb"),f.getvalue(),f.getstring());
输出正常
0xabcdef0123456789=1010101111001101111011110000000100100011010001010110011110001001b