以二进制格式输出对象基本思路是直接将对象的内存数值以二进制的格式输出,但是如何获取对象内存的二进制结构 n.XgGT=L
是关键。解决方法是通过位操作找出对象内存的每一个bit的值。并把该方法封装成一个迭代器。 >P ~j@Lv
要注意的问题是位操作符只能对整数类型进行操作,为了对所有类型的对象都有效,必须将对 c{j)beaS
象当作char数组来处理。 uann'ho?q
template<class Container> s6k(K>Pl
class bit_iterator : public std::iterator<bidirectional_iterator_tag, S1#5oy2
void, void> c8Nl$|B
{ Nw '$r
public: Q^8/"aV\
explicit bit_iterator(Container& c) : m_container(&c) mFmxEv
{ tL M@o|:
m_size = 8*sizeof(Container); gwbV$[.X
m_index = 0; Z*'<9l_1
} sB5@6[VDI
explicit bit_iterator() : m_container(0) >T)tAZ?WK
{ @F/,~|{iM
m_size = 8*sizeof(Container); 2({|LQqk
m_index = m_size; n~ZZX={a
} ]xGpN ]u
bool operator* () niyI$OC
{ Za]~[F
char mask = 1; vX_;Y#uD
char* pc = (char*)m_container; ?R_fg
int i = (m_size-m_index-1)/8; A
b+qLh&?
int off = (m_size-m_index-1)%8; S`Z[MNY
mask <<=off; NA$%Up
return pc & mask; ipE|)Ns
}
[?bq4u`
bit_iterator<Container>& operator++() U6.hH%\}@
{ CwD=nT5`
m_index++; -2j[;kgt}
return *this; s4j]kH
} ~x^Ra8A
bit_iterator<Container>& operator++(int) 9&{z?*
{ qP-_xpu]R
m_index++; sL,|+>7T^M
return *this; #pyFIUr=w
} RL[F 9g
bool operator==(bit_iterator<Container>& bitIt) Y`3\Z6KlV
{ [+L!c}#
return m_index == bitIt.m_index; %rV|{@J `
} <zm:J4&>T
bool operator!=(bit_iterator<Container>& bitIt) fmD~f
{ +BDW1%
return !(*this == bitIt); qcC(#0A>
} !<out4Mz"
protected: "ruYMSpU
Container* m_container; 3
2"f'{
private: _
^'QHWP
int m_size; ilyF1=bp
int m_index; nd$92H
}; luW"|
uw/N`u
用该迭代器可以将任意类型对象以二进制格式输出: 4C )sjk?m
double a = 10; Lyz8DwZ
copy(bit_iterator<double>(a), bit_iterator<double> (), ostream_iterator<bool>(cout, ""));