以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 5tl($j
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 F%IvgXt5
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 "A]#KTP
象当作char数组来处理。 yJ4ZB/ZQ
template<class Container> L*FQ`:lZ
class bit_iterator : public std::iterator<bidirectional_iterator_tag, X/ lmj_v
void, void> tID=I0D
{ "\+.S]~
public: 6d(D>a
explicit bit_iterator(Container& c) : m_container(&c) I8f='
{ C`=YGyj=TL
m_size = 8*sizeof(Container); U:0Ma6<
m_index = 0; [`kk<$=,&
} w+u1"
explicit bit_iterator() : m_container(0) NwyNl
{ L;-V Yo#
m_size = 8*sizeof(Container); an2Yluc;
m_index = m_size; <q&4Y+b
} Rga
*68s|&
bool operator* () .: k6Kg
{ ;EQ7kuJQ?
char mask = 1; g'AxJ
char* pc = (char*)m_container;
<Hr~|oG
int i = (m_size-m_index-1)/8; G!+Mu2
int off = (m_size-m_index-1)%8; GfV#^qi
mask <<=off; &grqRt
return pc & mask; a}Z+"D
}
]0XlI;ah
bit_iterator<Container>& operator++() VWc)AfKe
{ Bo$dIn2_
m_index++; rK\9#[?x
return *this; F+ %l=
fs
} ERy=lP~gV
bit_iterator<Container>& operator++(int) <HnpI
{ r{KQ3j9O
m_index++; IGOEqUw*
return *this; 82iFk`)T
} =!\Y;rk
bool operator==(bit_iterator<Container>& bitIt) p\R&vof*
{ !Df>Q5~g
return m_index == bitIt.m_index; .C` YO2,
} G@txX
'
bool operator!=(bit_iterator<Container>& bitIt) ~@DdN5
{ !t+ 3DMPn
return !(*this == bitIt); @N]]Cf>x
} Lg~ll$
U
protected: G6dUm_iB
Container* m_container; 5^K\<+{~B
private: {&J~P&,k
int m_size; e%EO/ 2"
int m_index; @nAl*#M*D
}; W{c
Z7$d
#{?~XS
用该迭代器可以将任意类型对象以二进制格式输出: bct8~dY
double a = 10; JT&RaFX
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));