Unions
union是D中可用的特殊数据类型,使您可以在同一内存位置存储不同的数据类型。 您可以定义具有许多成员的联合,但在任何给定时间只能有一个成员包含值。 联合提供了一种有效的方法,可以将相同的内存位置用于多种用途。
在D中定义 Union
要定义联合,必须以与定义结构时非常相似的方式使用union语句。 union语句定义了一个新的数据类型,为您的程序提供了多个成员。 union语句的格式如下 -
union [union tag] {
member definition;
member definition;
...
member definition;
} [one or more union variables];
union tag是可选的,每个成员定义都是一个普通的变量定义,例如int i; 或浮动f; 或任何其他有效的变量定义。 在union的定义结束时,在最后一个分号之前,您可以指定一个或多个union变量,但它是可选的。 这是你定义一个名为Data的联合类型的方式,它有三个成员i , f和str -
union Data {
int i;
float f;
char str[20];
} data;
Data类型的变量可以存储整数,浮点数或字符串。 这意味着单个变量(相同的内存位置)可用于存储多种类型的数据。 您可以根据需要在联合内部使用任何内置或用户定义的数据类型。
联盟占用的内存足够大,可以容纳联盟中最大的成员。 例如,在上面的示例中,Data类型将占用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的任何成员,我们使用member access operator (.) 。 成员访问运算符被编码为联合变量名称和我们希望访问的联合成员之间的句点。 您可以使用union关键字来定义联合类型的变量。
例子 (Example)
以下示例解释了联合的用法 -
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
在这里,所有成员都打印得非常好,因为一次使用一个成员。