C中的数组



一,一维数组

1.一维数组的含义:是一组相同类型元素的集合,定义数组时必须指定其元素的类型和个数。其大小与元素的类型和个数有关。数组可以存任何类型的数据,但不能存函数。

2.创建:

 
 

type_t arr_name [const_n];//type_t是数组的元素类型;const_n是常量,用来指定数组的大小;

注意:[  ]里要给一个常量,整形常量大于0,不能使用变量。在c语言中const 修饰的常量也不能使用(c++允许)。

下面看一个例子:

#include<stdio.h>                       
#include<windows.h>
int main()
{
	const int n = 10;
	int a[n];
	printf("%d\n", sizeof(a));    
	system("pause");
	return 0;
}

这个程序报错 :

3.初始化:在创建数组的同时给数组的内容一些合理初始值。

 int arr1[] = { 1, 2, 3, 4, 5 };
	char arr2[] = "abc";//{a,b,c,\0}
	char arr3[3] = { 'a', 'b', 'c ' };
	char*p = "abcdef";//{a,b,c,d,e,f,\0}

4.在内存中的存储:

下面看个代码:

#include<stdio.h>
#include<windows.h>
int main()
{
	int arr[10] = { 0 };
	int size = sizeof(arr) / sizeof(arr[0]);//数组的大小
	int i = 0;
	for (i=0; i < size; i++)
	{
		printf("&arr[%d]=%p\n", i, &arr[i]);
	}
	system("pause");
	return 0;
}

输出结果是:

从打印结果可以看出数组在内存中是连续存放的。如果没有初始化,结果都是随机值。

5,指针的认识:指针就是地址。

指针变量在32位系统下,永远占4个byte,其值为某一个内存的地址。指针可以指向任何地方,但是不是任何地方你都能通过这个指针变量访问到。

int *p的理解:int*是指针变量,*是解引用,p是指针(地址),也就是说,我们把p称为指针变量,p 里存储的内存地址处的内存称为p所指向的内存。指针变量p里存储的任何数据都将被当作地址来处理

下面看一个代码:

int n=10;
int *p=&n;//把n的地址放在指针变量中
*p=20;//n的内容

这个运行结果是n=20,即*p=n.

6.一维数组访问指针

首先来看一个程序:

#include<stdio.h>                       
#include<windows.h>
int main()
{
        printf("%p\n", a);//0020fde0
	printf("%p\n", a[0]);//00000001
	printf("%p\n", &a);//0020fde0
	printf("%p\n", &a[0]);//0020fde0
        printf("%p\n", *a);//00000001
	system("pause");
	return 0;
}

可以看出a,&a,&a[0]的结果一样,其实呢,a[0]是一个元素(首元素),*p也是首元素,a是整个数组,虽然&a[0]和&a的值一样,但其意义不一样。前者是数组首元素的首地址,而后者是数组的首地址。由此可见,数组作为右值时,数组名就是首元素地址。即a=&a[0].也可以得到a+i=&a[i].

再看一个代码:

#include<stdio.h>                       
#include<windows.h>
int main()
{
	int a[10] = {0};
	int i = 0;
	int *p = a;
	for (i = 0; i < sizeof(a) / sizeof(a[0]); i++)
	{
		*(p + i) = i;
	}
	for (i = 0; i < sizeof(a) / sizeof(a[0]); i++)
	{
		printf("%d\n", *(p + i) = i);
	}
	system("pause");
	return 0;
}

输出结果为0,1,2,3,4,5,6,7,8,9.由此可见*(p+i)=a[i].

二,二维数组

二维数组就看成一个一位数组。

1.二维数组的创建:

int arr[3][4];
char arr[3][5];
double arr[2][4]

2.初始化:

intarr[3][4] = {1,2,3,4};      //  1234 1234 1234
intarr[3][4] = {{1,2},{4,5}};   // 1200 4500 0000

3二维数组在内存中也是连续储存的。

4.二维数组的指针访问:

#include<stdio.h>
#include<windows.h>
int main()
{
	int arr[3][4] = { 0 };
	int*p = &arr[0][0];
	int i = 0;
	for (i = 0; i < 3 * 4; i++)
	{
		*(p + i) = i;//*(p+i)=arr[i]
	}
	for (i = 0; i < 3; i++)
	{
		int j = 0;
		for (j = 0; j < 4; j++)
		{
			printf("%d ", arr[i][j]);//打印结果是0,1,2,3,4,5,6,7,8,9,10,11
		}
	}
	system("pause");
	return 0;
}

注意:指针加1就是加上所指类型的大小。

三,数组作为函数参数:

数组传参是会发生降维问题,一维数组传参时会降成指向其内部元素类型的指针;二维数组传参时会降成一级指向其内部元素类型的指针。

#include<stdio.h>
#include<windows.h>
void fun(int arr[][4], int size)
{
	printf("%d\n", sizeof(arr));//打印结果是4,这里降成了int型指针。
}
int main()
{
	int arr[3][4];
	int size = sizeof(arr) / sizeof(arr[0]);
	fun(arr, size);
	system("pause");
	return 0;	
}



猜你喜欢

转载自blog.csdn.net/snowyuuu/article/details/79999829