union的用法

联合(union)在C/C++里面见得并不多,但是在一些对内存要求特别严格的地方,联合又是频繁出现,那么究竟什么是联合、怎么去用、有什么需要注意的地方呢?就这些问题,我试着做一些简单的回答,里面肯定还有不当的地方,欢迎指出!
1、什么是联合?
  
“联合”是一种特殊的类,也是一种构造类型的数据结构。在一个“联合”内可以定义多种不同的数据类型,一个被说明为该“联合”类型的变量中,允许装入该“联合”所定义的任何一种数据,这些数据共享同一段内存,已达到节省空间的目的(还有一个节省空间的类型:位域)。 这是一个非常特殊的地方,也是联合的特征。另外,同struct一样,联合默认访问权限也是公有的,并且,也具有成员函数。

2、联合与结构的区别?
  
“联合”与“结构”有一些相似之处。但两者有本质上的不同。在结构中各成员有各自的内存空间,一个结构变量的总长度是各成员长度之和(空结构除外,同时不考虑边界调整)。而在“联合”中,各成员共享一段内存空间, 一个联合变量的长度等于各成员中最长的长度。应该说明的是,这里所谓的共享不是指把多个成员同时装入一个联合变量内, 而是指该联合变量可被赋予任一成员值,但每次只能赋一种值, 赋入新值则冲去旧值。

   下面举一个例了来加对深联合的理解。
   
例4:

#include <stdio.h>
void main()
{
        union number
       {                  /*
定义一个联合*/
               int i;
               struct
               {             /*
在联合中定义一个结构*/
                       char first;
                       char second;
               }half;
        }num;
       num.i=0x4241;         /*联合成员赋值*/
        printf("%c%c\n",num.half.first, num.half.second);
        num.half.first='a';   /*联合中结构成员赋值*/
        num.half.second='b';
        printf("%x\n", num.i);
        getchar();
}
    输出结果为:
     AB
     6261
    从上例结果可以看出: 当给i赋值后, 其低八位也就是first和second的值; 当给first和second赋字符后, 这两个字符的ASCII码也将作为i 的低八位和高八位。

3.联合的经典用法

在这里联合的基本语法不想多说了,没理解的可以去查询,union一般用于互斥的情况以用来节省内存。在这里说一种union的经典用法。也是一道经典面试题

主要是用联合来判断一个机器是大端机还是小端机。

主要的程序代码如下:

union   select

   char b;

    int a;

};

select temp.a = 1;

if(temp.b == 1)printf("this is litter  endian\n");

else printf("big endian\n");



 


### Union 关键字的用法 #### 在 C/C++ 中 `union` 是一种特殊的数据结构,在 C 和 C++ 编程语言中被广泛使用。它允许在同一内存位置存储不同的数据类型[^1]。这意味着 `union` 的所有成员共享同一块内存空间,因此一次只能有一个成员具有有效值。 以下是关于 `union` 的一些重要特性及其语法: - **定义 union** 使用 `union` 定义时,其大小取决于最大成员变量所占用的空间。 ```c union Data { int i; float f; char str[20]; }; ``` - **访问 union 成员** 可以通过点运算符来访问 `union` 的成员,类似于结构体的操作方式。 ```c union Data data; data.i = 10; // 设置整数值 printf("%d\n", data.i); // 输出整数部分 data.f = 22.5f; // 覆盖之前的整数值并设置浮点数 printf("%f\n", data.f); ``` 需要注意的是,当修改其中一个成员时,其他成员的内容可能会受到影响,因为它们共用相同的内存区域。 #### 在 SQL 中 SQL 中的 `UNION` 运算符用于合并两个或多个 SELECT 查询的结果集。为了成功执行 UNION 操作,查询中的列数量以及对应列的数据类型必须匹配。 基本语法如下所示: ```sql SELECT column_name(s) FROM table1 UNION SELECT column_name(s) FROM table2; ``` 如果希望保留重复项,则可以改用 `UNION ALL` 来提高性能,因为它不会尝试去除重复记录。 示例代码片段展示如何利用 SQL 的 `UNION` 功能组合来自不同表的信息: ```sql -- 假设有两张表格 employees 和 contractors 都有 name 字段 SELECT name AS person_name FROM employees UNION SELECT name FROM contractors; ``` 上述语句会返回一个去重后的人员名单列表。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值