了解指针(2)

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];//存放整型指针的数组

                             

7.指针数组模拟二维数组

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值