结构体链表

本文介绍了结构体的定义与长度原则,包括如何在内存中存储结构体数组和指针数组。讲解了进程的内存空间划分,如数据段、代码段、堆和栈。讨论了联合体的特性及其在判断大小端中的应用,并概述了链表的基本概念,强调了链表在内存管理上的灵活性。
摘要由CSDN通过智能技术生成

数据结构定义:
struct A
{
    int a;
    char b[];
};
struct A a1;a2;

结构体指针定义(使用前一定要分配空间)
struct A *p = (struct A*)malloc(sizeof(struct A));

结构体长度的原则
1.一定是最长成员的整数倍(double除外 是4的倍数)
2.每个成员的偏移量一定是成员长度的整数倍

三、结构体数组
struct A stu[5]

四、结构体指针数组(使用前一定要分配空间)
struct A stu[5]
for(i = 0; i < 5; i++)
{
    stu[i] = (struct A*)malloc(sizeof(struct A))
}

数据在内存中的存储
进程:正在运行的程序叫做进程,每个进程内核都会为它分配4g的虚拟内存空间,其中3g为用户态,1g为内核态。
程序的运行时数据存在用户态中。
用户态的划分:
1.数据段
    初始化的数据:全局变量,静态变量
    未初始化的数据:未进行显示初始化的全局变量和静态变量(BSS段)
2.代码段:具有只读属性
3.堆:动态进行分配的内存空间(malloc(),free())
4.栈:局部变量,包括形参堆和栈的区别:
栈:申请和释放由操作系统管理、
堆:申请和释放由用户管理

联合体:所有成员共享一段内存(只为最长成员分配空间)
定义ÿ

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值