以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 +p
Y*BP+~i
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 5>e#SW
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 m'b9 f6
象当作char数组来处理。 MN.h,^b
template<class Container> Ddr.kXIpo
class bit_iterator : public std::iterator<bidirectional_iterator_tag, ,_$}>MY;
void, void>
4.7 PL
{ y_7lSo8<
public: QQPT=_P]
explicit bit_iterator(Container& c) : m_container(&c) oE
H""Bd
{ 9[5qN!P;y
m_size = 8*sizeof(Container); }^@Q9<P^E
m_index = 0; iaAj|:
} IOjp'6Yr
explicit bit_iterator() : m_container(0) iiw\
{ y$Rr,]L
m_size = 8*sizeof(Container); $Sx(vq6(
m_index = m_size; /~O>He
} `Pcbc\"*y
bool operator* () 6VsgZ"Il
{ 8nj^x?bn
char mask = 1; sT*D]J
2
char* pc = (char*)m_container; :"~SKJm
int i = (m_size-m_index-1)/8; 5vmc'Om
int off = (m_size-m_index-1)%8; sgGXj7
mask <<=off; Nf!g1D"U
return pc & mask; `+\6;nM
} hn-!W;j
bit_iterator<Container>& operator++() Ki,SFww8r
{ 3tjF4C>h|
m_index++; cUH.^_a
return *this; ,'nd~{pX"(
} 3bd(.he2u
bit_iterator<Container>& operator++(int) q9h3/uTv
{ (qbL=R"
m_index++; M&v;#CV
return *this; j TyR+#Wn
} zFba("E Z
bool operator==(bit_iterator<Container>& bitIt) %2;Nj;
J$
{ 2I|`j^
return m_index == bitIt.m_index; c;13V(Djy
} ]VkM)< +
bool operator!=(bit_iterator<Container>& bitIt) dKk#j@[n"
{ (^@rr[.o7
return !(*this == bitIt); d:X@zUR*)
} X"k:+
protected: yd|ro G/
Container* m_container; Km)VOX[ZZ
private: d$H
int m_size; hb. ^&
int m_index; k Xg&}n7
}; Lhz*o6)
Sk6B>O <:
用该迭代器可以将任意类型对象以二进制格式输出: zJ
$&`=
double a = 10; X 3dXRDB'
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));