📅  最后修改于: 2020-11-04 05:13:54             🧑  作者: Mango
联合是D中可用的特殊数据类型,它使您可以将不同的数据类型存储在同一内存位置。您可以定义具有多个成员的联合,但是在任何给定时间只能有一个成员包含一个值。联合提供了一种有效的方式,可以将同一内存位置用于多种用途。
要定义联合,您必须以与定义结构时非常相似的方式使用联合声明。 union语句定义了一种新的数据类型,该程序具有多个成员。联合声明的格式如下-
union [union tag] {
member definition;
member definition;
...
member definition;
} [one or more union variables];
union标签是可选的,每个成员定义都是一个普通变量定义,例如int i;或浮动f;或任何其他有效的变量定义。在并集定义的末尾,在最后一个分号之前,您可以指定一个或多个并集变量,但这是可选的。这是定义名为Data的并集类型的方法,该类型具有三个成员i , f和str-
union Data {
int i;
float f;
char str[20];
} data;
数据类型的变量可以存储的整数,a浮点数,或字符的字符串。这意味着可以使用一个变量(相同的内存位置)来存储多种类型的数据。您可以根据需要在联合体内使用任何内置或用户定义的数据类型。
工会占用的内存将足以容纳工会的最大成员。例如,在上面的例子中,数据类型将占用20个字节的存储空间,因为这是可通过占据的最大空间。以下示例显示上述联合占用的总内存大小-
import std.stdio;
union Data {
int i;
float f;
char str[20];
};
int main( ) {
Data data;
writeln( "Memory size occupied by data : ", data.sizeof);
return 0;
}
编译并执行上述代码后,将产生以下结果-
Memory size occupied by data : 20
要访问联合的任何成员,我们使用成员访问运算符(。) 。成员访问运算符被编码为联合变量名称和我们希望访问的联合成员之间的句点。您将使用union关键字定义union类型的变量。
以下示例说明了union的用法-
import std.stdio;
union Data {
int i;
float f;
char str[13];
};
void main( ) {
Data data;
data.i = 10;
data.f = 220.5;
data.str = "D Programming".dup;
writeln( "size of : ", data.sizeof);
writeln( "data.i : ", data.i);
writeln( "data.f : ", data.f);
writeln( "data.str : ", data.str);
}
编译并执行上述代码后,将产生以下结果-
size of : 16
data.i : 1917853764
data.f : 4.12236e+30
data.str : D Programming
在这里,您可以看到union的i和f成员的值被破坏了,因为分配给变量的最终值已占据了内存位置,这就是str成员的值被很好地打印的原因。
现在,让我们再次查看同一示例,其中一次将使用一个变量,这是拥有并集的主要目的-
import std.stdio;
union Data {
int i;
float f;
char str[13];
};
void main( ) {
Data data;
writeln( "size of : ", data.sizeof);
data.i = 10;
writeln( "data.i : ", data.i);
data.f = 220.5;
writeln( "data.f : ", data.f);
data.str = "D Programming".dup;
writeln( "data.str : ", data.str);
}
编译并执行上述代码后,将产生以下结果-
size of : 16
data.i : 10
data.f : 220.5
data.str : D Programming
在这里,所有成员都打印得很好,因为一次只使用一个成员。