以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 (FZL>
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 5)V]qV$
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 *2crhI*@>
象当作char数组来处理。 uoFH{.)
template<class Container> l)D18
class bit_iterator : public std::iterator<bidirectional_iterator_tag, M]!\X6<_
void, void> PYr#vOH
{ {r.#R|
4v
public: kac@yQD
explicit bit_iterator(Container& c) : m_container(&c) 6}R^L(^M
{ vrn IEur
m_size = 8*sizeof(Container); TveCy &
m_index = 0; :Oo
} "-XL Y_
explicit bit_iterator() : m_container(0) 0*VRFd4
{ qhVDC
m_size = 8*sizeof(Container); KL*ZPKG
m_index = m_size; Gh0H)
q
} +xRja(d6
bool operator* () <oV
_EZ
{ i:OD)l
char mask = 1; G,>tC`!
char* pc = (char*)m_container; /a17B
int i = (m_size-m_index-1)/8; z_!P0`
int off = (m_size-m_index-1)%8; 8<3J!X+
mask <<=off; _Pa(5-S'KR
return pc & mask; D9e"E1f+"
} }r`!p5\$K0
bit_iterator<Container>& operator++() l#%Y]1*
{ }txHuq1Q.
m_index++; K"eR6_k
return *this; $;7?w-.
} :Y
y+%
bit_iterator<Container>& operator++(int) >!A&@1[M
{ eOy{]<l3
m_index++; KQ?E]}rZ
return *this; ItQI M#
} e`4OlM]
bool operator==(bit_iterator<Container>& bitIt) +Es3iE @
{ aMuc]Wy#
return m_index == bitIt.m_index; 4 *He<2g
} Wf13Ab
bool operator!=(bit_iterator<Container>& bitIt) Bcrd}'no
{ zF<*h~
return !(*this == bitIt); v[CX-CBZ?
} xZtA) Bp
protected: 6VolTy@(x
Container* m_container; /#9O{)
private: HoymGU`w
int m_size; M]jzbJ3Q
int m_index; $ePAsJ
}; )HS|pS:
wGd8q xa
用该迭代器可以将任意类型对象以二进制格式输出: ({Fus@/
double a = 10; "vH@b_>9|
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));