c++中union的用法是什么

avatar
作者
筋斗云
阅读量:0

在C++中,union是一种特殊的数据结构,允许在同一内存位置存储不同的数据类型。它的用法如下:

  1. 节省内存:使用union可以节省内存,因为它只会为其中一个成员分配内存,而不是为每个成员都分配内存。

  2. 数据共享:union的成员共享同一块内存,这意味着同一时间只能存储一个成员的值。当一个成员被赋值后,它将覆盖之前存储的成员的值。

  3. 数据类型转换:可以使用union进行数据类型转换。例如,将一个float类型的值存储在union中的一个成员,然后以int类型的方式读取该值。

以下是一个示例,说明了如何使用union:

#include <iostream> using namespace std;  union Data {    int i;    float f;    char str[20]; };  int main() {    Data data;        cout << "Memory size occupied by data : " << sizeof(data) << endl;     data.i = 10;    cout << "data.i : " << data.i << endl;        data.f = 220.5;    cout << "data.f : " << data.f << endl;        strcpy(data.str, "C++ Programming");    cout << "data.str : " << data.str << endl;     return 0; } 

输出结果为:

Memory size occupied by data : 20 data.i : 10 data.f : 220.5 data.str : C++ Programming 

在上面的示例中,我们定义了一个union Data,它有三个成员:i(整数类型)、f(浮点数类型)和str(字符数组类型)。我们可以看到,这三个成员共享同一块内存,因此只能存储其中一个成员的值。在main函数中,我们分别将整数、浮点数和字符串分配给union的成员,并打印它们的值。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!