C语言数组的创建初始化以及使用

本文详细介绍了C语言中的数组,包括如何创建和初始化数组,以及数组在内存中的存储方式。特别强调了数组名通常代表首元素地址,但sizeof运算符会返回整个数组的大小,而取址运算符&则获取整个数组的地址。同时,文章还探讨了二维数组在参数传递中的行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

#include<stdio.h>

int main()
{
	int array[10];//创建
	char ch[10];
	int n = 10;
	int arr1[n] = {0};//err []必须为常量或者常量表达式
	return 0;
}

在这里插入图片描述

int array[10] = { 1, 2, 3 };//创建并初始化
	//不完全初始化,剩余元素默认初始化为0
	int arr2[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };//完全初始化
	int arr3[10] = { 0 };
	int arr4[] = { 1, 2, 3, 4, 5 };//不指定大小

	char ch1[] = { 'a', 'b', 'c', 'd' };//4个元素
	char ch2[] = "abcd";//5个元素 默认带\0
	printf("%d\n", sizeof(ch1));//4
	printf("%d\n", sizeof(ch2));//5
	printf("%d\n", strlen(ch1));//随机值
	printf("%d\n", strlen(ch2));//4

输出结果:
在这里插入图片描述
在这里插入图片描述

#include<stdio.h>

int main()
{
	int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8 };
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);

	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

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

#include<stdio.h>

int main()
{
	int arr[] = { 1, 2, 3, 4, 5, 6, 7, 8 };
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);

	for (i = 0; i < sz; i++)
	{
		printf("%p\n", &arr[i]);
	}
	return 0;
}

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

在这里插入图片描述

    int arr[3][4];//三行四列的二维数组
	char arr1[3][4];

在这里插入图片描述

	int arr[3][4] = { 1, 2, 3, 4, 5 };
	//三行四列的二维数组

在这里插入图片描述

	int arr[3][4] = { { 1, 2 }, { 3, 4 }, 5 };
	//三行四列的二维数组

在这里插入图片描述

	int arr[][4] = { { 1, 2 }, { 3, 4 }, 5 };
	//二维数组,即使你给它初始化了,行数可以省略,但是列数是不能省略的

在这里插入图片描述

#include<stdio.h>

int main()
{
	int arr[][4] = { { 1, 2 }, { 3, 4 }, 5 };
	//二维数组,即使你给它初始化了,行数可以省略,但是列数是不能省略的
	int i = 0;//行数
	int j = 0;//列数

	for (i = 0; i < 3; i++)
	{
		for (j = 0; j < 4; j++)
		{
			printf("%d ", arr[i][j]);
		}
		printf("\n");
	}

	return 0;
}

输出结果:

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

#include<stdio.h>

int main()
{
	int arr[][4] = { { 1, 2 }, { 3, 4 }, 5 };
	//二维数组,即使你给它初始化了,行数可以省略,但是列数是不能省略的
	int i = 0;//行数
	int j = 0;//列数

	for (i = 0; i < 3; i++)
	{
		for (j = 0; j < 4; j++)
		{
			printf("&arr[%d][%d] = %p\n", i ,j,&arr[i][j]);
		}
		printf("\n");
	}

	return 0;
}

输出结果:

在这里插入图片描述
在这里插入图片描述
在内存中连续存放的用途:

#include<stdio.h>

int main()
{
	int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
	int*p = arr;
	int i = 0;
	for (i = 0; i < 10; i++)
	{
		printf("%d ", *p);
		p++;
	}
	return 0;
}

输出结果:

在这里插入图片描述

#include<stdio.h>

int main()
{
	int arr[3][4] = { { 1, 2 }, { 3, 4 },{ 5 } };
	int*p = &arr[0][0];
	int i = 0;
	for (i = 0; i < 12; i++)
	{
		printf("%d ", *p);
		p++;
	}
	return 0;
}

输出结果:

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

#include<stdio.h>

void bubble_sort(int arr[],int sz)
{
	int i = 0;
	//冒泡排序的趟数
	for (i = 0; i < sz - 1; i++)
	{
		//一趟冒泡排序
		int j = 0;
		for (j = 0; j < sz - 1 - i; j++)
		{
			if (arr[j]>arr[j + 1])
			{
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
			}
		}
	}
}

void print_arr(int arr[], int sz)//此处必须为arr[]      err - arr
{
	int i = 0;
	for (i = 0; i < sz - 1; i++)
	{
		printf("%d ", arr[i]);
	}
	printf("\n");
}

int main()
{
	int arr[] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
	int sz = sizeof(arr) / sizeof(arr[0]);//不可在函数内部
	//排序 - 排成升序
	//arr是数组
	//数组传参的时候,数组名会发生降级
	//数组名降级为数组首元素的地址
	//数组传参实际上穿的是数组首元素的地址
	print_arr(arr, sz);
	bubble_sort(arr,sz);//冒泡排序的方法
	print_arr(arr, sz);
	return 0;
}

输出结果:

在这里插入图片描述绝大多数情况下:数组名是首元素的地址。有两个例外:
sizeof(数组名) , 数组名是整个数组,计算的是整个数组的大小。
&数组名,数组名表示整个数组,去除的是整个数组的地址。

二维数组传参:

#include<stdio.h>

void print_arr(int arr[3][3], int row, int col)
{
	int i = 0;
	int j = 0;
	for (i = 0; i < col; i++)
	{
		for (j = 0; j < col; j++)
		{
			printf("%d ",arr[i][j]);
		}
		printf("\n");
	}
}

int main()
{
	int arr[3][3] = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
	print_arr(arr,3,3);
	return 0;
}

输出结果:

在这里插入图片描述

<think>好的,我现在需要解决用户关于C语言数组动态初始化的问题。首先,我得明确用户的需求。用户已经知道静态初始化的方法,但想了解动态初始化,也就是在程序运行时根据需求分配和初始化数组。那动态初始化通常涉及到内存的动态分配,比如使用malloc、calloc或者realloc函数。 首先,我需要回顾C语言中动态内存分配的相关知识。动态数组创建通常需要用到malloc函数,这个函数在<stdlib.h>头文件中声明。malloc分配指定大小的内存块,并返回指向该内存的指针。例如,int *arr = (int*)malloc(n * sizeof(int)); 这里n是数组的大小,由用户输入或程序运行时确定。分配后,还需要检查是否成功分配,因为malloc可能返回NULL,如果内存不足的话。 接下来,初始化动态数组。动态分配的内存区域初始值是未定义的,可能包含垃圾值,所以通常需要显式初始化初始化方法有多种,比如循环赋值、使用memset函数(但需要注意memset是按字节初始化的,适用于0或-1这样的值),或者用calloc函数,它会在分配内存的同时将每个字节初始化为0。 用户可能需要具体的示例代码,所以我要准备几个不同的例子。例如,使用malloc分配后手动输入每个元素的值,或者用循环赋初始值。还有使用calloc的例子,以及用memset的例子,同时要提醒用户memset的局限性,比如不能用于初始化非0或-1的整型数组。 另外,动态数组使用完毕后,必须用free函数释放内存,防止内存泄漏。这也是需要强调的一点,因为动态分配的内存不会自动回收。 现在要考虑用户可能的疑问,比如动态数组和静态数组的区别,动态初始化的适用场景,以及常见错误,比如忘记检查malloc的返回值,导致程序崩溃,或者忘记释放内存。此外,可能还需要解释指针和数组的关系,因为动态数组本质上是通过指针来操作的。 然后,根据用户提供的引用内容,引用[5]提到memset只能用于0和-1,这点很重要,需要包含在回答中。引用[3]和[4]提到初始化列表,但动态初始化无法使用初始化列表,所以需要说明动态和静态初始化的不同方法。 最后,整理步骤,给出清晰的示例代码,并解释每个步骤的作用。确保代码正确,语法正确,比如正确使用malloc和free,类型转换等。同时,生成相关问题,帮助用户进一步学习,比如动态内存分配失败处理,调整数组大小的方法,以及动态数组与静态数组的比较。 总结一下,回答的结构应该是:先解释动态初始化的概念,然后分点说明方法(malloc+循环、calloc、memset),每个方法给出示例代码,强调注意事项,最后提醒释放内存。接着生成相关问题,引导深入学习。</think>### C语言数组动态初始化方法及示例 动态初始化指在程序运行时根据需求分配内存并初始化数组元素,常用于数组长度不确定的场景。以下是几种常见方法: --- #### 1. **使用`malloc`分配内存后手动初始化** 通过`malloc`动态分配内存,再通过循环或用户输入初始化元素: ```c #include <stdio.h> #include <stdlib.h> int main() { int n; printf("输入数组长度: "); scanf("%d", &n); // 动态分配内存 int *arr = (int*)malloc(n * sizeof(int)); if (arr == NULL) { printf("内存分配失败"); return 1; } // 手动初始化(例如赋值为0) for (int i = 0; i < n; i++) { arr[i] = 0; // 或通过scanf输入 } // 使用后释放内存 free(arr); return 0; } ``` --- #### 2. **使用`calloc`分配并自动初始化为0** `calloc`在分配内存时会将所有字节初始化为0: ```c int *arr = (int*)calloc(n, sizeof(int)); // 元素自动为0 if (arr == NULL) { // 处理错误 } ``` --- #### 3. **使用`memset`批量初始化** `memset`按字节初始化,适用于将数组初始化为`0`或`-1`[^5]: ```c int *arr = (int*)malloc(n * sizeof(int)); memset(arr, 0, n * sizeof(int)); // 所有元素设为0 ``` --- #### 注意事项 - **内存释放**:动态分配的数组必须通过`free()`释放,否则会导致内存泄漏。 - **错误检查**:分配后需检查指针是否为`NULL`,避免操作无效内存。 - **初始化范围**:`memset`仅适用于按字节填充的值(如`0`或`-1`),其他值需用循环赋值[^5]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值