以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 ]h`d>#Hw!
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 .F _u/"**
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 %82:?fq
象当作char数组来处理。 OwDwa~
template<class Container> xj]^<oi<
class bit_iterator : public std::iterator<bidirectional_iterator_tag, Efpju(
void, void> anKflt3
{ ?ZhBS3L
public: \mt Y_O
explicit bit_iterator(Container& c) : m_container(&c) `Xi)';p
{ bXM&VW?OP
m_size = 8*sizeof(Container); \ZSq ZDq
m_index = 0; :"i2`y;u
} ( pCU:'"
explicit bit_iterator() : m_container(0) ^7:UC\_
{ B'PS-Jr
m_size = 8*sizeof(Container); B\ZCJaMb
m_index = m_size; ^%U`|GBZp
} B" ]a8}u
bool operator* () P+e {,~o
{ p7.~k1h
char mask = 1; wr>6Go%
char* pc = (char*)m_container; 'OU3-K
int i = (m_size-m_index-1)/8; :$XlYJrjK
int off = (m_size-m_index-1)%8; @RdNAP_6
mask <<=off; DoN]v
return pc & mask; @c>MROlrlF
} .\
vrBf
bit_iterator<Container>& operator++() K'K/}q<
{ LF:~&
m
m_index++; G}]'}FUp
return *this; [xdVuL;N
} +mO/9m
bit_iterator<Container>& operator++(int) '+GYw$
{ + =U9<8
m_index++; *oh,Va
return *this; k~QmDq
} A'n7u'6=
bool operator==(bit_iterator<Container>& bitIt) W$z^U)|t
{ Ubwmn!~
return m_index == bitIt.m_index; w[^lxq
} po*r14f
bool operator!=(bit_iterator<Container>& bitIt) B+c,3@)x
{ ' 1dhdm8
return !(*this == bitIt); c11;(
} T7?z0DKi
protected: 5m>f1`4JS
Container* m_container; y8v0>V0)
private: a\p`J 9Z@
int m_size; h6:|RGF
int m_index; BGstf4v>A<
}; /1+jQS
l5enlYH
用该迭代器可以将任意类型对象以二进制格式输出: k/Q8:qA
double a = 10; 1_@vxi~aW_
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));