博客
关于我
struct和union分析
阅读量:134 次
发布时间:2019-02-27

本文共 726 字,大约阅读时间需要 2 分钟。

一、struct

空结构体占多大内存???下面例子:

#include 
struct str{ };int main(){ struct str obj1; struct str obj2; printf("%d\n", sizeof(struct str)); printf("%d, %ox\n", sizeof(obj1), &obj1); printf("%d, %ox\n", sizeof(obj2), &obj2); return 0;}

结果为0,而且obj1和obj2的起始地址相同。【gcc编译器】

实际上 在C语言中并无说明空结构体占多大内存

通过实际实验得出:gcc编译器中,都为零,起始地址相同;g++编译器中,都为1 起始地址不同 但不可通过 "."来访问内存空间。

二、union与struct的区别

struct中的每个域在内存中都独立分配空间;union只分配最大域的空间,所有域共享这个空间。下面例子:

#include 
struct str_test{ int a; int b; int c;};union uni_test{ int a; int b; int c;};int main(){ printf("%d\n", sizeof(struct str_test)); printf("%d\n", sizeof(union uni_test)); return 0;}

union使用的注意事项:

union的使用受系统大小端的影响:

大端模式:

小端模式:

你可能感兴趣的文章
mysql备份恢复出错_尝试备份/恢复mysql数据库时出错
查看>>
mysql复制内容到一张新表
查看>>
mysql复制表结构和数据
查看>>
mysql复杂查询,优质题目
查看>>
MySQL外键约束
查看>>
MySQL多表关联on和where速度对比实测谁更快
查看>>
MySQL多表左右连接查询
查看>>
mysql大批量删除(修改)The total number of locks exceeds the lock table size 错误的解决办法
查看>>
mysql如何做到存在就更新不存就插入_MySQL 索引及优化实战(二)
查看>>
mysql如何删除数据表,被关联的数据表如何删除呢
查看>>
MySQL如何实现ACID ?
查看>>
mysql如何记录数据库响应时间
查看>>
MySQL子查询
查看>>
Mysql字段、索引操作
查看>>
mysql字段的细节(查询自定义的字段[意义-行列转置];UNION ALL;case-when)
查看>>
mysql字段类型不一致导致的索引失效
查看>>
mysql字段类型介绍
查看>>
mysql字段解析逗号分割_MySQL逗号分割字段的行列转换技巧
查看>>
MySQL字符集与排序规则
查看>>
MySQL字符集乱码
查看>>