以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 ,M$h3B\;r
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 "i&9RA!1
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 1JV-X G6
象当作char数组来处理。 ssl.Y!
template<class Container> :.(A,
class bit_iterator : public std::iterator<bidirectional_iterator_tag, F6_en z
void, void> '_ys4hz}
{ %8>0;ktU
public: t(}g;O-
explicit bit_iterator(Container& c) : m_container(&c) 7v}(R:*
{ 'f8'|o)
m_size = 8*sizeof(Container); ;_0frX
m_index = 0; $y%IM`/w
} LtV,djk
explicit bit_iterator() : m_container(0) "d2JNFIHb
{ u,]qrlx{
m_size = 8*sizeof(Container); FJBB@<>:
m_index = m_size; csV3mzP
} %zO>]f&
bool operator* () {:=]J4]
{ H;#C NB<e
char mask = 1; /h@3R[k
char* pc = (char*)m_container; AB<%GzW0(
int i = (m_size-m_index-1)/8; NHe[,nIV
int off = (m_size-m_index-1)%8; U#{(*)qr
mask <<=off; Hxn#vAc
return pc & mask; !t?5U_on
} |O;vWn'U2
bit_iterator<Container>& operator++() R:[#OH.c
{ H#G3CD2&
m_index++; 0D0uzUD-
return *this; u"8KH
u5C@
} #VxN [770
bit_iterator<Container>& operator++(int) lUw=YM
{ IuMJ-"
m_index++; t_+owiF)M
return *this; B_RF)meux
} 3mL(xpT.8z
bool operator==(bit_iterator<Container>& bitIt) lHE \Z`
{ R0K{wY58
return m_index == bitIt.m_index; \y+^r|IL
} ZuKOscVS#T
bool operator!=(bit_iterator<Container>& bitIt) OF,_6"m
{ [MD"JW?4B
return !(*this == bitIt); ;WgzR_'!'
} EAz>`~
protected: fP 3t0cp
Container* m_container; PJ,G_+b!
private: kIRjoKf <F
int m_size; f`8?]@y{
int m_index; B;nIKZ
}; 3,J{!
V;gC[7H
用该迭代器可以将任意类型对象以二进制格式输出: +jO#?J
double a = 10; bGK-?BE5+A
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));