1.对数组名的理解
数组名就是数组首元素的地址
int *p=&aff[0];等价于int * p=arr;
其实数组名就是数组首元素的地址,但是有两个例外
1.sizeof(数组名)
这里的数组名表示整个数组,计算的是整个数组的大小,单位是字节
2.&数组名
这里的数组名也表示整个数组,取出的是整个数组的地址(整个数组的地址和数组首元素的地址是有区别的)
&arr和arr有什么区别
通过这个可以知道&数组名不同
一个整型的地址+1 ------ 跳过一个整型
一个字符的地址+1 ------ 跳过一个字符
一个数组的地址+1 ------ 跳过一个数组
2.使用指针访问数组
*(arr+i) <==>arr[i]
*(arr+i)-------->*(i+arr)
i[arr]
数组就是数组,是一块连续的空间,是存放一个或多个数组的
指针变量是一个变量,是存放地址的变量
数组和指针不是一回事
但是可以使用指针来访问数组
原因:数组在内存中是连续存放的
指针的元素可以遍历数组,取出数组的内容 指针运算
3.一维数组传参的本质
一维数组传参的本质,传递的是数组首元素的地址,形参即使写成数组的形式本质上也是一个指针变量(所以形参的部分可以写成数组的形式,也可以写成指针的形式)
4.冒泡排序
对乱序的进行排序,两两相邻元素比较,不满足就交换,满足就寻找下一对
一趟冒泡排序只会解决一个数
若有n个元素,就要进行n-1趟排序,而且每一趟排序后就会使下一趟要比较的对数少一对
5.二级指针
二级指针变量是用来存放一级指针变量的地址的
6.指针数组
char arr[10]; //字符数组 存放字符的数组
int arr[5]; //整型数组 存放整型的数组
指针数组 存放指针的数组,每个元素都是指针类型
char* arr[5];//存放字符指针的数组
int * arr[6];//存放整型指针的数组