??
一,一维数组 1.一维数组的含义:是一组相同类型元素的集合,定义数组时必须指定其元素的类型和个数。其大小与元素的类型和个数有关。数组可以存任何类型的数据,但不能存函数。
2.创建:
type_t arr_name [const_n];
//type_t是数组的元素类型;const_n是常量,用来指定数组的大小;
注意:[]里要给一个常量,整形常量大于0,不能使用变量。在c语言中const 修饰的常量也不能使用(c++允许)。
下面看一个例子:
#include
#include
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
#include
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
#include
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
#include
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
#include
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就是加上所指类型的大小。
三,数组作为函数参数:
数组传参是会发生降维问题,一维数组传参时会降成指向其内部元素类型的指针;二维数组传参时会降成一级指向其内部元素类型的指针。
【C中的数组】
#include
#include
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;
}
推荐阅读
- C语言基础|C语言中阶第五篇(写一个强制关机的程序,以及goto语句跳出多层循环的应用)
- 浅析memcpy内存拷贝函数
- 将字符串中的字符反向排列
- C语言基础(函数的声明与定义)
- linux网络编程
- C语言基础|.C/C++面试题
- C语言基础|C语言 链表操作
- C语言基础|C/C++中的i18n(wcstombs和mbstowcs使用
- Vc中 windows 常用的数据类型