以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 Y~Vc|zM^(
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 ?u;m
],w!
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 9z{g3m70@
象当作char数组来处理。 b<#zgf
template<class Container> f*88k='\W
class bit_iterator : public std::iterator<bidirectional_iterator_tag, (3Xs
void, void> i%F2^R@!q/
{ ZR0 OqSp]
public: EE | c@M^
explicit bit_iterator(Container& c) : m_container(&c) zBwqIJfM
{ X[dH*PV
m_size = 8*sizeof(Container); "VHT5k
m_index = 0; R]Z#VnL@qz
} $cuBd
explicit bit_iterator() : m_container(0) g:xg ~H2
{ s]`6uyW"
m_size = 8*sizeof(Container); AZ^>osr
m_index = m_size; `F1Yfm
jZT
} . XbDb
bool operator* () )c1Pj#|
{ Zn40NKYc
char mask = 1; WlY\R>x#
char* pc = (char*)m_container; \6.dGKK
int i = (m_size-m_index-1)/8; c yP+a
int off = (m_size-m_index-1)%8; .HGK 3
mask <<=off; U(x$&um(l
return pc & mask; &'i>d&
} TOgH~R=
bit_iterator<Container>& operator++() PY4a3dp
U
{ Z,\(bW
qF
m_index++; pFiE2V_aS
return *this; UHTxNK@}
} i$}G[v<4
bit_iterator<Container>& operator++(int) Oml3=TV
{ Er8F_,M+
m_index++; `mYp?NjR_
return *this; =w8 0y'
} r8N)]HsZH
bool operator==(bit_iterator<Container>& bitIt) &z*4Uij
{ ;9fWxH
return m_index == bitIt.m_index; <nV 3`L&]
} Wnp[8IEU
bool operator!=(bit_iterator<Container>& bitIt) qzHsqlof
{ 4DP<)KX
return !(*this == bitIt); PR(KDwsT&l
} )@y'$)5s
protected: z Z~t,>
Container* m_container; ~R=p[h)
private: &`>dY
/Y
int m_size; MIZ!+[At
int m_index; ,,IK}
}; :x3DuQP
6 !fq658
用该迭代器可以将任意类型对象以二进制格式输出: JlE+CAny
double a = 10; prIJjy-F
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));