前言 \nqo%5XL
RH~3M0'0
熟悉C的程序员都知道union(联合体)的用法,利用union可以用相同的存储空间存储不同型别的数据类型,从而节省内存空间。当访问其内成员时可用"."和"->"来直接访问。在C++出现后,它继承了union并保留了其在C中的特性。但是在C++中的union又有了新的扩展,这需要大家了解,要不然你会感到费解和迷惑。下面我讲两点。 wE).>
MF[z-7
一、在union中存储对象 l>v{
?G?gy2
在C中union中可以存储任意类型的内置数据类型,那么在C++中union是否可以存储对象呢?还是让我们看一个例子吧,这比任何言语都能说明问题,不是吗? #\bP7a+
:[M[(
#pragma warning(disable : 4786) |)W!jC&k
#include Y~n`~(
using namespace std; 0>!/rR7
v&3O&y/1v
class TestUnion Y(GN4@`S
{ )'q%2%Ak
public: Wn!G.(Jq
TestUnion(long l):data_(l) p-GT`D
{ he)ulB
}; 'nK~'PZ,
int data_; .9LL+d
}; C4$/?,K(
]Qi,j#X
typedef union _tagUtype_ yZSvn[f
{ FQf#*
TestUnion obj; U
|F>W~%
}UT; <?$kI>Ot
MB:n~>ga
int main (void) 6CNS%\A
{ ~4
FDKUC
return 0; a]1i/3/
} QJ];L7Hbo
*kaJ*Ti-/
j$eCe<.3
这样不行,union中不可以存储TestUnion类的对象,但在C中union可以存储struct呀,为什么不能存储类的对象呢?很简单,请问,在C中union可以存储带有构造函数的struct吗?对了,在C中的struct是没有构造函数的。所以如果C++中union可以存储有构造函数的类的对象就不太符合逻辑,那不是说C++和C完全兼容吗?不错,正因为这一点,C++中union不可以存储有构造函数的类的对象,但是可以存储不带构造函数的类的对象,这样就和C保持一致了,不想信你试试。对TestUnion类的声明进行如下修改: L2Ux9_S
$cK^23H/Fj
class TestUnion lSc,AOXp
{ i+~QDo(Pi
public: I$N7pobh
int data_; ) Ypz!
}; C<he4n.
]+IVSxa!u
再进行编译,一切OK!。但是这样却失去了C++的构造初始化特性,这样做是没有任何意义的,我只是在说其在C++中的语义,并不是推荐大家使用(绝对不推荐)。但是我们可以在union中存储对象的指针,从而引用不同的对象类型。不用我再多说了吧,大家还是试试吧! f]}}yBte`
X}apxSd"
二、类中union的初始化 <`JG>H*B6
0|2%# E
由于union的共享内存特点,我们可以使我们的类存储不同的型别而不浪费内存空间,在类中我们可以声明一个union存储不同型别的指针,示例如下: |t\KsW
Pi%tsKk%
#pragma warning(disable : 4786) ,o&<WMD
#include T|f_~#?eV
P,1exgq9
using namespace std; *IlQ5+3I
ZA.fa0n
class TestUnion h}6b&m
{ hZ#\t
enum StoreType{Long,Const_CharP}; '?R =P
union mcMb*?]
{ ry,}F@P&
const char* ch_; \|!gPc%s
long l_; P`!Ak@N
} data_; 'aPCb`^;w
StoreType stype_; Orc>.~+f%A
TestUnion(TestUnion&); Bi_J5 If
TestUnion& operator=(const TestUnion&); ~}%&p&
p
public: RQ5P}A
3H
TestUnion(const char* ch); 1OPfRDn.bk
TestUnion(long l); NlFo$Y
operator const char*() const {return data_.ch_;} QAXYrRu
operator long() const {return data_.l_;} )GCLK<,swu
}; sVD([`Nmc
5xv,!/@
TestUnion::TestUnion(const char* ch):data_.ch_(ch),stype_(Const_CharP) Z`"n:'&
{ J]]\&MtaO
} ,A?v,Fs>O[
Jh(mbD
TestUnion::TestUnion(long l):data_.l_(l),stype_(Long) <