前言 R|!4Y`
Iu0K#.s_
熟悉C的程序员都知道union(联合体)的用法,利用union可以用相同的存储空间存储不同型别的数据类型,从而节省内存空间。当访问其内成员时可用"."和"->"来直接访问。在C++出现后,它继承了union并保留了其在C中的特性。但是在C++中的union又有了新的扩展,这需要大家了解,要不然你会感到费解和迷惑。下面我讲两点。 ~"EkX
a|?CC/Ra
一、在union中存储对象 . 36'=K
OY~5o&Oa
在C中union中可以存储任意类型的内置数据类型,那么在C++中union是否可以存储对象呢?还是让我们看一个例子吧,这比任何言语都能说明问题,不是吗? ?vf{v
WP^%[?S2
#pragma warning(disable : 4786) UDyvTfh1X
#include y9\s[}c_
using namespace std; 1aYO:ZPy
:'GTCo$3
class TestUnion Kr]!BI?z
{
=sG(l
public: 3 ;.{
O%bX
TestUnion(long l):data_(l) Jc9SHCJ
{ #_7}O0?c3
}; {yVi/*;f^
int data_; v-G(bw3
}; X+iA"B
f$V']dOj1q
typedef union _tagUtype_ {br4B7b
{ =]W{u`
TestUnion obj; 5bmtUIj
}UT; )IZ$R*Y{
@ n;WVG
int main (void) ~n"V0!:'4
{ a3Es7R+S
return 0; $
Qg81mu
} mq'q@@:c
HdWghxz?)
=#%e'\)a
这样不行,union中不可以存储TestUnion类的对象,但在C中union可以存储struct呀,为什么不能存储类的对象呢?很简单,请问,在C中union可以存储带有构造函数的struct吗?对了,在C中的struct是没有构造函数的。所以如果C++中union可以存储有构造函数的类的对象就不太符合逻辑,那不是说C++和C完全兼容吗?不错,正因为这一点,C++中union不可以存储有构造函数的类的对象,但是可以存储不带构造函数的类的对象,这样就和C保持一致了,不想信你试试。对TestUnion类的声明进行如下修改: aKCCFHq t!
WlZ[9,:p1
class TestUnion ^r;}6
{ o}WbW }&
public: Y!&dj95y
int data_; >47,Hq:2
}; uX}M0W
by6E
"7%
再进行编译,一切OK!。但是这样却失去了C++的构造初始化特性,这样做是没有任何意义的,我只是在说其在C++中的语义,并不是推荐大家使用(绝对不推荐)。但是我们可以在union中存储对象的指针,从而引用不同的对象类型。不用我再多说了吧,大家还是试试吧! `5 e#9@/e
NqqLRgMOR'
二、类中union的初始化 _rjCwo\
|k
4+I
由于union的共享内存特点,我们可以使我们的类存储不同的型别而不浪费内存空间,在类中我们可以声明一个union存储不同型别的指针,示例如下: >>^c_ 0"O
oF,8j1
#pragma warning(disable : 4786) (:T~*7/"
#include VdK-2O(.-
o'Tqqrr
using namespace std; ` S85i*
mg >oB/,'Z
class TestUnion sFS_CyN!7
{ zP=J5qOZ8
enum StoreType{Long,Const_CharP}; bk4%lYJ"
union $8it&/JP,
{ f "Iv
const char* ch_; M;Vx[s,#,
long l_; d\Dxmb]o
} data_; 6oUT+^z#
StoreType stype_; 5QmF0z)wR
TestUnion(TestUnion&); "t_] Qu6
TestUnion& operator=(const TestUnion&); h r6f}2
public: toIljca
TestUnion(const char* ch); Ii|<:BW
TestUnion(long l); }P}l4k1W
operator const char*() const {return data_.ch_;} p3x(:=
operator long() const {return data_.l_;} ?6j@EJ<2q
}; $g|g}>Sc
1YnDho;~
TestUnion::TestUnion(const char* ch):data_.ch_(ch),stype_(Const_CharP) W=)}=^N0
{ /[EI0~P
} k7W8$8v
8%nTDSp&t
TestUnion::TestUnion(long l):data_.l_(l),stype_(Long) g>f(5
{ ;utjW1y
} aUA+%
dd4yS}yBlR
int main (void) PS=crU@"H
{ r&ToUU 5
TestUnion pszobj("yuankai"); F1Z20)8K
TestUnion lobj(1234); e[e2X<&0RT
cout<(pszobj)< cout< &a