指针的进阶
之前简略的学习了指针,总结一下之前学习指针的概念
指针是存放地址的变量,把地址存放到变量里叫指针变量。
指针的大小是固定的4个或8个字节(32位平台和64位平台)。
指针是有类型的,类型的大小决定了指针的±整数的步长,指针解引用操作的时候的权限。
指针的加减运算
这个章节,我们继续深入的学习指针
字符指针
字符指针是存放字符类型地址的指针,char * p
例如:
int main()
{
char x = "w";
char* p = &x;
*p = 'r';
return 0;
}
还有一种使用方式:
根据以上的知识来做一道练习题,加以巩固
int main()
{
char str1[] = "hello china";
char str2[] = "hello china";
const char* str3 = "hello china";
const char* str4 = "hello china";
if (str1 == str2)
printf("str1 和 str2 相同\n");
else
printf("str1 和 str2 不同\n");
if (str3 == str4)
printf("str3 和 str4 相同\n");
else
printf("str3 和 str4 不同\n");
return 0;
}
题解:
str 1 和 str 2
str 3 和 str 4
指针数组
指针数组是存放指针的数组,数组中存放的是指针
int* arr[3];
整形指针的数组
char *arr2[4];
一级字符指针的数组
char **arr3[5];
二级字符指针的数组
例如:
模拟二维数组
二维数组的地址是连续的
下面数组的地址不是连续存放的
数组指针
数组指针的定义
数组指针是存放数组的指针
如果想把数组存放到数组指针怎么写呢
int arr[10] = {
1,2,3,4,5};
int (*p)[10] = &arr;
这里*p 代表 p 是指针变量,[10]是指向的是一个大小10个整形的数组
所以 p 是数组指针,存放的是数组的地址
- 如果我想把 float*x[ 5 ]的数组存放到数组指针中,改怎么写呢
float * x[5]
数组指针:·float* (*pd)[5]
floart* 代表指向的是类型是float*
(*pd)代表指针
[ 5 ] 代表指向的是 5 个元素
数组名和&数组名
int arr[10];
- arr 和 &arr 的区别在哪里呢
- arr是数组首元素的地址
- 那 &arr呢?
看下面代码:
从图片可以看出,二种方式的地址都是一样的
那在看一段代码:
从上面代码的结果可以看出: - arr(5E8) 和 arr+1(5EC) 相差4个字节
- &arr(5E8)和 &arr+1(610)相差40个字节
- 从结果可以得知道,&arr表示的是数组的地址,加一就意味这加的是整个数组的大小
数组指针的使用
数组的指针是怎么用的呢?
数组指针指向的是数组,那数组指针中存放的应该是数组的地址。
例如:
正常二维数组的使用
void print(int str[3][5], int x, int y)
{
int i = 0;
for (i = 0; i < x; i++)
{
int j = 0;
for (j = 0; j < y; j++)
{
printf("%d ", str[i][j]);
}
printf("\n");
}
}
int main()
{
int arr[3][5] = {
{
1,2,3,4,5},{
2,3,4,5,6},{
3,4,5,6,7} };
print(arr, 3, 5);
}
数组指针的使用
数组名arr 代表首元素地址,但是二维数组代表的是第一行的地址
所以函数传arr,其实相当于第一行起始的地址
可以用数组指针来接收
void print(int (*str)[5], int x, int y)
{
int i = 0;
for (i = 0; i < x; i++)
{
int j = 0;
for (j = 0; j < y; j++)
{
printf("%d ", str[i][j]);
}
printf("\n");
}1/*9*lrew
}
数组参数、指针参数
总结一下数组和指针传参时,函数的参数的设计
一维数组传参
数组传参
二种写法都可以
void Add(int arr[])
{
}
数组传参,参数用数组接收,数组的大小可以不写也没有问题
--------------<