以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 !PI0oh
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 +gNX7xuY
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 ZIy(<0
象当作char数组来处理。 B3.X}ys#
template<class Container> `&,_xUA
class bit_iterator : public std::iterator<bidirectional_iterator_tag, /J.0s0@
void, void> H<z30r/-w
{ |rFJ*.nD
public: pLo;#e8'f
explicit bit_iterator(Container& c) : m_container(&c) m9I(TOw
{ tnJ`D4
m_size = 8*sizeof(Container); N.vG]%1"
m_index = 0; d3(+ztmG!
} 2{gwY85:
explicit bit_iterator() : m_container(0) 2D_6
{ ++gPv}:$X
m_size = 8*sizeof(Container); ZR2\dH*
m_index = m_size; l3\9S#3-^
} PbQE{&D#
bool operator* () ]3 j[3'
{ qw)Key
char mask = 1; #4lHaFq
char* pc = (char*)m_container; P;>!wU~*
int i = (m_size-m_index-1)/8; 8nf4Jk8r
int off = (m_size-m_index-1)%8; \`&xprqAw
mask <<=off; %cd]xQpCp
return pc & mask; i
_8zjj7
} _rG-#BKW8L
bit_iterator<Container>& operator++() 3U>S]#5}
{ wH!}qz/
m_index++; Iw*C*%}[Z
return *this; L*IU0Jy>
}
+Bn?-{h=
bit_iterator<Container>& operator++(int) KG-UW
{ I,w^?o
m_index++; dkETM,
return *this; i >J:W"W
} EO"=\C,
bool operator==(bit_iterator<Container>& bitIt) <w;D$l}u
{ C\J@fpH(t`
return m_index == bitIt.m_index; #'#4hJ*YC
} Vj29L?3
bool operator!=(bit_iterator<Container>& bitIt) [KD}U-(Wg
{ M Ey1~h/
return !(*this == bitIt); @H3|u`6V
} s~/57S
protected: ]m RF[b$
Container* m_container; Fu#Y7)r
private: +OKA_b"wB
int m_size; 1RmBtx\<
int m_index; ^sJ1 ^LT
}; 2k%Bl+I
+7`u9j.
用该迭代器可以将任意类型对象以二进制格式输出: l;XUh9RF`A
double a = 10; FU^Y{sbDg
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));