指针的进阶一

目录

1.字符指针

2.数组指针

3.指针数组

4.数组传参

5.函数指针


1.字符指针

复制代码
int main()
{
const char* pstr = "hello world.";
printf("%s\n", pstr);
return 0;
}

pstr中存放的就是字符串的首元素地址,并不是把字符串hello world 放到字符指针pstr中了。

2.指针数组

指针数组是一个存放指针的数组

cpp 复制代码
1 int* arr1[10]; 
2 char *arr2[4]; 
3 char **arr3[5];

第一行代码表示整形指针的数组

第二行代码表示一级字符指针的数组

第三行代码表示二级字符指针的数组

3.数组指针

cpp 复制代码
int (*p)[10]

p先和*结合,说明p是一个指针变量,然后指着指向的是一个大小为10个整型的数组。所以p是一个指针,指

向一个数组,叫数组指针。

注意:[ ]的优先级要高于*号的,所以必须加上()来保证p先和*结合。

4.数组传参

cpp 复制代码
#include <stdio.h>

int main()
{
    int arr[10] = { 0 };
    printf("arr = %p\n", arr);
    printf("&arr= %p\n", &arr);
    printf("arr+1 = %p\n", arr+1);
    printf("&arr+1= %p\n", &arr+1);
    return 0;
}

根据上面的代码我们发现,其实&arr和arr,虽然值是一样的,但是意义应该不一样的。

实际上: &arr 表示的是数组的地址,而不是数组首元素的地址。(细细体会一下)

本例中 &arr 的类型是: int(*)[10] ,是一种数组指针类型

数组的地址+1,跳过整个数组的大小,所以 &arr+1 相对于 &arr 的差值是40.

5.函数指针

cpp 复制代码
void test()
{
printf("hehe\n");
}
//下面pfun1和pfun2哪个有能力存放test函数的地址?
void (*pfun1)();
void *pfun2();

首先,能给存储地址,就要求pfun1或者pfun2是指针,那哪个是指针? 答案是:

pfun1可以存放。pfun1先和*结合,说明pfun1是指针,指针指向的是一个函数,指向的函数无参数,返回值类型为void。

相关推荐
炒鸡菜6667 小时前
程序人生-Hello’s P2P
c语言·程序人生·职场和发展
2401_884602277 小时前
程序人生-Hello’s P2P
c语言·c++
初中就开始混世的大魔王7 小时前
2 Fast DDS Library概述
c++·中间件·信息与通信
娇娇yyyyyy8 小时前
C++基础(6):extern解决重定义问题
c++
Neteen8 小时前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
灰色小旋风9 小时前
力扣——第7题(C++)
c++·算法·leetcode
Ralph_Y9 小时前
C++网络:一
开发语言·网络·c++
程序猿编码10 小时前
探秘 SSL/TLS 服务密码套件检测:原理、实现与核心设计(C/C++代码实现)
c语言·网络·c++·ssl·密码套件
故事和你9110 小时前
sdut-程序设计基础Ⅰ-实验二选择结构(1-8)
大数据·开发语言·数据结构·c++·算法·优化·编译原理
像素猎人10 小时前
数据结构之顺序表的插入+删除+查找+修改操作【主函数一步一输出,代码更加清晰直观】
数据结构·c++·算法