C语言学习笔记

本文探讨了32位平台上的内存地址结构、指针大小与访问速度,包括数组名的特殊含义、内存对齐规则,以及函数调用和动态内存分配的实例。重点讲解了柔性数组、内存分析和内存分配的灵活性,以及C语言中涉及的内存管理知识点。
摘要由CSDN通过智能技术生成

相关书籍

在这里插入图片描述

1、如何产生地址

在32位平台上,会产生32位地址线/数据线,通电会有正(1)、负(0)之分,地址编号

也就是会有2的32次方个地址,且每个存储单元的大小是一个字节,也就是最多可以访问4G的内存。

2、指针大小

在32位平台上一个指针大小占4个字节,64位平台占8个字节

3、访问速度

寄存器>高速缓存>内存>硬盘

1、&数组名 数组名不是首元素地址,取出的是整个数组的地址
2、sizeof(arr) sizeof(数组名) 数组名表示的是整个数组
//除此以外在任何地方看到的数组名都是代表首元素的地址

CPU只有加法器

整数在内存中的存储

在这里插入图片描述

在这里插入图片描述

小端存储模式

在这里插入图片描述
在这里插入图片描述

函数调用的内存分析

在这里插入图片描述
函数栈帧的创建和销毁
在这里插入图片描述
在这里插入图片描述

结构体内存对齐

在这里插入图片描述
在这里插入图片描述
20个字节
在这里插入图片描述

位段的内存分配在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

C语言执行流程

在这里插入图片描述

动态内存分配 CDemo22

在这里插入图片描述

realloc
在这里插入图片描述

//笔试题(该题有bug)
void GetMemory(char* p)
{
	p = (char*)malloc(100);
}
void demo01()
{
	char* str = NULL;
	GetMemory(str);
	strcpy(str, "hello");
	printf("%s\n", str);
}

空指针不是有效的地址,没有指向一块有用的空间
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
解决方案2
在这里插入图片描述

在这里插入图片描述

柔性数组

//柔性数组		结构中的最后一个元素允许是未知大小的数组,这就叫做『柔性数组』成员。
struct S
{
	int n;
	int arr[0];//未知大小的-柔性数组成员-数组的大小是可以调整的
};

void demo06()
{
	//struct S s;
	//printf("%d\n",sizeof s);   4
	struct S* ps = (struct S*)malloc(sizeof(struct S) + 5 * sizeof(int));

	ps->n = 100;
	int i = 0;
	for (i=0;i<5;i++)
	{
		ps->arr[i] = i;//0 1 2 3 4
	}

	struct S* ptr = realloc(ps, 44);

	if (ptr != NULL)
	{
		ps = ptr;

		for (i = 5; i < 10; i++)
		{
			ps->arr[i] = i;
		}
		for (i = 0; i < 10; i++)
		{
			printf("%d\n", ps->arr[i]);
		}
	}

	free(ps);
	ps = NULL;
} 
这不是柔性数组
 struct S2
{
	int n;
	int* arr;
};

void demo07()
{
	struct S2* ps = (struct S2*)malloc(sizeof(struct S2));
	ps->arr = (int*)malloc(5 * sizeof(int));
	int i = 0;
	for (i=0;i<5;i++)
	{
		ps->arr[i] = i;
	}
	for (i = 0; i < 5; i++)
	{
		printf("%d\n", ps->arr[i]);
	}

	//调整大小
	struct S2* ptr = realloc(ps->arr, 10 * sizeof(int));
	if (ptr != NULL)
	{
		ps->arr = (int*)ptr;

		for (i = 5; i < 10; i++)
		{
			ps->arr[i] = i;
		}
		for (i = 0; i < 10; i++)
		{
			printf("%d\n", ps->arr[i]);
		}
	}

	free(ps->arr);
	free(ps);
	ps->arr = NULL;
	ps = NULL;
}

这不是柔性数组

文件操作

在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值