C语言union中包含struct 小结

本文通过三个实例展示了C语言中union如何与包含struct的交互,探讨了小端模式下数据存储的特性。通过设置并打印union中的不同成员,观察到数据在内存中的表示和变化,揭示了内存对齐和数据类型转换的原理。

#include<stdio.h>
int main()
{
         union
                {
                        int i;
                         struct
                                {
                                        int j;
                                        int m;
                                }byte;
                         struct
                                {
                                        char k;
                                        char p;
                                        char q;
                                        char s;
                                }bit;
                }jin;
     jin.bit.p=0x2;
     jin.i=0x12345678;
 printf("%x\n",jin.bit.k); 
  printf("%x\n",jin.bit.p);
  printf("%x\n",jin.bit.q);
  printf("%x\n",jin.bit.s);
  printf("%d\n",sizeof(jin));
}

编译:
[root@localhost algorithm]# gcc jin.c -o jin
^[[A[root@localhost algorithm]# ./jin
78
56
34
12
8

证明了我的编译器是小端模式。

 

#include<stdio.h>
int main()
{
         union
                {
                        int i;
                         struct
                                {
                                        int j;
                                        int m;
                                }byte;
                         struct
                                {
                                        char k;
                                        char p;
                                        char q;
                                        char s;
                                }bit;
                }jin;

     jin.i=0x12345678;  //与一互换
     jin.bit.p=0x2;
 printf("%x\n",jin.bit.k); 
  printf("%x\n",jin.bit.p);
  printf("%x\n",jin.bit.q);
  printf("%x\n",jin.bit.s);
  printf("%d\n",sizeof(jin));
}

编译:
[root@localhost algorithm]# gcc jin.c -o jin
^[[A[root@localhost algorithm]# ./jin
78
2
34
12
8

与一相比,56变成了2.

 

#include<stdio.h>
int main()
{
         union
                {
                        int i;
                         struct
                                {
                                        int j;
                                        int m;
                                }byte;
                         struct
                                {
                                        char k;
                                        char p;
                                        char q;
                                        char s;
                                }bit;
                }jin;
     jin.bit.p=0x2;
     jin.i=0x12345678;
  printf("%x\n",jin.bit.k);
  printf("%x\n",jin.bit.p);
  printf("%x\n",jin.bit.q);
  printf("%x\n",jin.bit.s);
  printf("%x\n",jin.byte.j);
  printf("%d\n",sizeof(jin));
 // printf("%x\n",jin.byte.j);

}

多了一行黑体。

 

编译:

[root@localhost algorithm]# vim jin.c
[root@localhost algorithm]# gcc jin.c -o jin
^[[A[root@localhost algorithm]# ./jin
78
56
34
12
12345678
8

打印多了12345678这一行。

若把黑体printf("%x\n",jin.byte.j);改为printf("%x\n",jin.byte.m);则打印的是随意的数字,因为没初始化m,空间只初始化一个int。

<think>嗯,用户问的是C语言中sizeof的使用方法和示例。之前提供的引用资料已经比较全面,包括三种主要使用场景:获取数据类型大小、数组名和指针的区别、sizeof与strlen的差异。用户看起来刚接触C语言,可能对底层内存分配不太熟悉,需要特别注意解释清楚三个易混淆点:1)数组名在sizeof中的特殊行为(不退化为指针)2)指针与数组名的差异3)sizeof计算结果依赖于目标系统。这些在之前的系统编程课程里学生最容易搞错。从引用内容看,用户提供的资料质量不错,但引用[3]的C++代码示例反而可能造成混淆,需要特别说明。另外原始引用里用%d打印size_t类型存在移植性问题,在正式回答中要纠正为%zu格式符。考虑设计三个主要示例模块:基础数据类型(强调跨平台差异)、数组相关计算(二维数组需重点演示)、结构体与指针(包括填充问题)。每个示例都准备配中文注释,把关键点写在printf输出结果里。最后加个常见错误小结应该很实用。</think> 在 C 语言中,`sizeof` 运算符用于查询**对象或类型在内存中所占的字节数**,属于编译时运算符,在编译阶段即可确定结果。以下是详细使用方法和示例: --- ### **一、基础用法** 1. **获取数据类型大小** ```c #include <stdio.h> int main() { printf("int: %zu 字节\n", sizeof(int)); // 通常为 4 字节 printf("char: %zu 字节\n", sizeof(char)); // 固定为 1 字节 printf("double: %zu 字节\n", sizeof(double)); // 通常为 8 字节 return 0; } ``` > 💡 输出结果取决于编译器和操作系统(如 32 位与 64 位系统)[^1]。 2. **获取变量大小** ```c int num = 10; double price = 99.9; printf("num 占 %zu 字节\n", sizeof(num)); // 等价于 sizeof(int) printf("price 占 %zu 字节\n", sizeof(price)); // 等价于 sizeof(double) ``` --- ### **二、数组相关用法** 1. **计算数组总大小** ```c int arr[10]; size_t size = sizeof(arr); // 返回数组总字节数:10 * sizeof(int) printf("arr 总大小:%zu 字节\n", size); // 若 int 占 4 字节,输出 40 ``` 2. **数组名 vs 指针的差异** ```c int arr[5] = {1,2,3,4,5}; int *ptr = arr; // 数组名退化为指针 printf("数组总大小:%zu\n", sizeof(arr)); // 输出 20(5 * 4字节) printf("指针大小:%zu\n", sizeof(ptr)); // 输出指针大小(通常 4 或 8 字节) printf("首元素指针:%zu\n", sizeof(&arr[0])); // 同样输出指针大小 [^2] ``` 3. **计算数组元素个数** ```c int arr[] = {10,20,30,40}; size_t length = sizeof(arr) / sizeof(arr[0]); // 40 / 4 = 10(推荐方法) printf("数组长度:%zu\n", length); // 输出 4 ``` --- ### **三、结构体与联合体** 1. **结构体大小** ```c struct Student { char name[20]; // 20 字节 int age; // 4 字节 double score; // 8 字节 }; printf("Student 大小:%zu\n", sizeof(struct Student)); // 可能为 32 字节(注意内存对齐) ``` 2. **联合体大小** ```c union Data { int i; char ch; float f; }; printf("Data 大小:%zu\n", sizeof(union Data)); // 输出最大成员大小(4 字节) ``` --- ### **四、sizeof 与 strlen 区别** | **特性** | `sizeof` | `strlen` | |----------------|------------------------------|------------------------------| | **作用** | 计算内存占用大小 | 计算字符串实际长度(不含'\0') | | **执行时机** | 编译时 | 运行时 | | **示例结果** | `char s[10]="abc"; sizeof(s)=10` | `strlen(s)=3` | > 示例: > ```c > char str[] = "hello"; > printf("sizeof: %zu\n", sizeof(str)); // 输出 6(包含结尾 '\0') > printf("strlen: %zu\n", strlen(str)); // 输出 5(不计算 '\0')[^3] > ``` --- ### **五、常见陷阱** ```c void func(int arr[]) { printf("函数参数中数组名大小:%zu\n", sizeof(arr)); // 输出指针大小(非数组大小)! } int main() { int a[5]; func(a); // 传递的是指针 return 0; } ``` > ⚠️ **关键点**:数组作为函数参数时会退化为指针,此时 `sizeof(arr)` 返回指针大小。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值