以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 kfC0zd+
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 Z.&\=qiY
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 x@P{l&:>
象当作char数组来处理。 6FfOH<\z6i
template<class Container> } :iBx
class bit_iterator : public std::iterator<bidirectional_iterator_tag, NTs;FX~g[
void, void> wh 0<Uv
{ v4?iOD
public: ^CzYDq
explicit bit_iterator(Container& c) : m_container(&c) ]kktoP|D
{ B%<e FFV\
m_size = 8*sizeof(Container); "oJ(J{Jat
m_index = 0; Ft%hh|$5y
} HN5W@5m:
.
explicit bit_iterator() : m_container(0) mkvvNm3
{ jyW[m,#(go
m_size = 8*sizeof(Container);
1S%k
m_index = m_size; "u}9@}*
} @^nu#R
bool operator* () jRkC/Lw
{ Mjpo1dw
char mask = 1; @b!"joEy
char* pc = (char*)m_container; U`R;P-
int i = (m_size-m_index-1)/8; Ru%|}sfd
int off = (m_size-m_index-1)%8; `ZHP1uQ<
mask <<=off; g+q@i{Yn
return pc & mask; ]XUl@Y.
} r$)$n&j
bit_iterator<Container>& operator++() ;##]G=%
{ D>ai.T%n
m_index++; 5#:pT
return *this; lHBI
} bk#xiuwT
bit_iterator<Container>& operator++(int) 5$l9@0D.\
{ #,f{Ok+
m_index++; 7-iIay1h"
return *this; lhn8^hOJ/
} >POO-8Q
bool operator==(bit_iterator<Container>& bitIt) ESQ!@G/n
{ V:
p)m&y6
return m_index == bitIt.m_index; &TN2 HZ-bJ
} B5=3r1Ly
bool operator!=(bit_iterator<Container>& bitIt) N}/>r D
{ !oSLl.fQd
return !(*this == bitIt); 4-4?IwS
} H;vZm[\0N-
protected: ~2%3FV^
Container* m_container; Rmh*TQu
private: F+=urc>w
int m_size; eO5ktEoJ
int m_index; go|>o5!g
}; cFfTYP9
p]LnE`v
用该迭代器可以将任意类型对象以二进制格式输出: 7s>a2
double a = 10; r7z6___
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));