以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 p:5NMo
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 )#cZ&
O
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 MP)Prl>
象当作char数组来处理。 kfZ`|w@q
template<class Container> u~ipB*Zf
class bit_iterator : public std::iterator<bidirectional_iterator_tag, aHmg!s}&
void, void> 7 QNx*8 p
{ Pd\4hy
public: Fa[^D~$l*
explicit bit_iterator(Container& c) : m_container(&c) )Uy%iE*
{ !Q15qvRS
m_size = 8*sizeof(Container); *DC/O(
0
m_index = 0; 1n[)({OQ
} 8.n#@%
explicit bit_iterator() : m_container(0) T3@2e0u )
{ _:=\h5}8
m_size = 8*sizeof(Container); HbI{Xf[6LP
m_index = m_size; ,;Wm>V)o
} vt2.
i$u
bool operator* () G<D8a2q
{ hTzj{}w
char mask = 1; \<*F#3U1
char* pc = (char*)m_container; (${ #l
int i = (m_size-m_index-1)/8; &K[sb%
int off = (m_size-m_index-1)%8; =eUKpYI
mask <<=off; 5X=1a*2']
return pc & mask; Sx'oa$J
} /MY's&D(
bit_iterator<Container>& operator++() BVNJas
{ nPdkvs
m_index++; i .uyfV&F
return *this; q
i yK
} O>qlWPht
bit_iterator<Container>& operator++(int) 41<h|WA
{ "Gp Tmu?
m_index++; w01[oU$x=
return *this; z+7V}aPM
} bE.<vF&
bool operator==(bit_iterator<Container>& bitIt) 4@3 \Ihv
{ c-(RjQ~M5
return m_index == bitIt.m_index; 'g)f5n a[
} :?\29j#*V
bool operator!=(bit_iterator<Container>& bitIt) iYgVSVNg
{ t!Cz;ajNi
return !(*this == bitIt); x\8g ICf
} 4X]/8%]V
protected: t3Gy *B
Container* m_container; Os-Z_zSl6
private: JX&]>#6|E
int m_size; SNOc1c<~
int m_index; rIPfO'T?
}; <q$Tk,
7HH@7vpJ^
用该迭代器可以将任意类型对象以二进制格式输出: E> GmFw
double a = 10; ?V8Fgd
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));