(C语言)自定义类型,枚举与联合

问:

1. 结构体在自引用的时候不能怎么样?可以怎么样?

2. Solve the problems:自定义一个学生结构体类型,要包含姓名,性别,年龄,六科成绩,家乡(也为结构体,包含家乡名称,家乡邮编,家乡简介,家乡历史)?

3. 结构体成员的对齐数就是什么与什么的什么?除什么外,每个成员的什么的什么就是什么?结构体的总大小,也就是什么?是所有成员什么的什么的什么?如果结构体成员是什么?就怎么理解?如果结构体成员也是什么?那么它的什么怎么算?

4. Solve the problems:想计算一下之前创建的学生结构体内存消耗是多少字节?

5. 结构体内存对齐本质上是一种什么做法?

6. 有一个宏叫什么可以验证结构体内存对齐?它计算什么的什么?两个参数是什么?

7. 设计结构体的时候要怎么样?

8. 结构体传参要传什么?

9. 位段也称为什么?其实还是什么?什么一模一样?好处在于什么?

10. 位段的成员类型必须是什么?并且都是怎么样的?每个成员后面的什么表示什么呢?有时会有什么发生?

11. 画图说明位段的内存分配是怎么样的?

12. 位段本来就是来怎么样的?因此与什么无关?

13. Solve the problems:Jeff不相信位段的存在,怎么样来证明位段的存在?

14. 枚举的关键字是什么?而联合体呢?

15. 什么和什么的什么,什么的什么都是与什么怎么样?

16. 联合体的特点是什么?意味着什么与什么?

17. 联合体大小计算需要先找出什么与什么?对于什么而言,什么就是什么?联合体大小应怎么样?最后还要对齐到什么的什么?

18. 联合体在内存中的存放可以用什么概括?

19. Solve the problems:我想用联合体判断一下当前机器的大小端字节序存储,并且顺便计算一下联合体大小,该怎么办?

20. Solve the problems:如何用联合体把16进制数11223344修改为11223355?


答:

1. 包含与自己类型一样的结构体,包含一个同类型的指针。

2.

//解决方法
struct Home
{
    char name[5];  
    char post[6];
    char introduce[14];
    int history;
};
struct Stu
{
    char name[6];
    char sex[3];
    int age;
    float score[6];
    struct Home place;
};

3. 自身大小,默认对齐数,较小值,第一个成员,对齐数,整数倍,起点偏移量,所占字节个数,对齐数,最大值,整数倍,数组,把数组元素看成一个个相同的成员,结构体,起点偏移量,自己成员对齐数的最大值的整数倍。

4. 72。

5. 拿空间换取时间。

6. offsetof,结构体成员,起始偏移量,结构体类型,结构体成员。

7. 尽量让占用空间小的成员集中在一起。

8. 结构体指针。

9. 位段式的结构体,结构体,作用与功能,节省空间。

10. 整型家族,同类型的,冒号与数字,该成员只占用这么多比特位,截断。

11.

12. 节省空间,结构体内存对齐。

13. 可以自己去调试内存里面验证。

14. enum,union。

15. 联合体,联合体变量,创建,联合体成员,访问,结构体,高度雷同。

16. 只有一个没水的公厕,我在拉时你不能用,我拉完后屎还是在的。

17. 最大成员的大小,所有成员最大对齐数,数组成员,成员大小,元素大小之和,≥最大成员大小,最大对齐数,整数倍。

18. 同一起点。

19.

//解决方法
union Elon
{
    int a;
    char b;
};
int main()
{
    union Elon x;
    x.b = 0;
    x.a = 1;
    if (x.b == 1)
    {
        printf("小端\n");
    }
    else
    {
        printf("大端\n");
    }
    printf("%d\n", sizeof(union Elon));
    return 0;
}

20.

union test
{
    int a;
    char b;
};
int main()
{
    union test m;
    m.a = 0x11223344;
    m.b = 0x55;
    printf("%x\n", m.a);
    return 0;
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

絕知此事要躬行

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值