c++

c++中union的用法是什么

小亿
82
2023-12-09 02:07:52
栏目: 编程语言

在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的成员,并打印它们的值。

0
看了该问题的人还看了