当前位置:网站首页>C——指针
C——指针
2022-07-17 09:19:00 【Java学不会】
指针
1、指针与变量
1.1、指针的概念
- 指针即
地址 - 变量的指针就是变量的
地址
1.2、指针的定义
- 定义指针的一般形式为: 基类型
*指针变量名;- int *p;
*: 指针说明符
1.3、指针的赋值
通过
取地址运算符赋值:&int a,*p; p=&a;通过另一个指针
int a,*p,*q; q=&a; p=q;空指针的定义- NULL表示空,其值为
0 - 空指针定义后不能引用
int *p=NULL; == int *p=0;- NULL表示空,其值为
1.4、指针的操作
&:取地址运算符*:去内容运算符:只有在定义时*为指针说明符,其它位置为取内容运算符
1.5、函数之间的地址传递
实参<——>形参
- 实参:地址
- 形参:指针
地址传递是双向影响
void fun(int *x,int *y){ *x+=*y; *y+=*x; } int main(){ int a=3,b=5; fun(&a,&b); printf("%d,%d\n",a,b); return 0; } 输出结果:8,13
2、指针与一维数组
2.1、一维数组的地址
- int arr_a[10];
- arr_a是
数组名,即一维数组的首地址,第0个(arr_a[0])元素的地址 - 数组名是常量(地址常量)
- arr_a是
- 一维数组常用表达式:
- a<==>&a[0]
- a+i<==>&a[i]
*(a+i)<==>a[i]
int a[]={ 1,2,3,4,5}; a[0]=1 *(a+2)=3 a[2]=3 *a=1
2.2、指向一维数组的指针
指针指向数组名,即把数组的首元素的地址
指针指向哪个元素,哪个就是首元素
指针可以做加减元素,即后移前移
int a[]={ 12,24,36,48,60},*P,*q; p=a;q=p+1; *p=12 *(p+2)=36 q[2]=48 *q+4=28*++p地址后移,先后移再使用;*p++先使用,再后移++*p地址的值+1数组名是地址常量,不可赋值指针是变量,可以赋值指针比较大小就是所在
位置比较大小指针相减就是
位置相减指针
不可相加
2.3、函数之间对一维数组的引用
| 实参 | 形参 | 传递方式 |
|---|---|---|
| 数组元素 | 变量 | 值传递 |
| 数组元素地址 | 指针 | 地址传递 |
| 数组名 | 数组或指针 | 地址传递 |
- 实参数组: 是一个数组,使用时需要定义长度
- 形参数组: 本质上是
指针,使用时无需定义长度
3、指针与二维数组
3.1、二维数组的地址
- int a[3][4];
- a是二维数组名,即二维数组的首地址,
第0行(a[0][0])的地址
- a是二维数组名,即二维数组的首地址,
- 二维数组地址和内容的引用方式:
- *(a+1)+2: 第1行第2列的
地址 - *(*(a+2)+3): 第2行第3列的
内容 - a[1]+2: 第1行第2列的
地址 - *(a[2]+3): 第2行第三列的
内容 *、[]出现任意一个代表地址*、[]出现任意两个代表内容
- *(a+1)+2: 第1行第2列的
3.2、指向二维数组的指针
- 指针指向二维数组,看作一维数组
int a[2][3]={ 1,2,3,4,5,6},*p; int m,s; p=&a[0][0]; m=(*p)*(*(p+2))*(*(p+4)); s=p[1]+p[3]+p[5]; m=15 s=12
4、数组指针
- int (*p)[4];
- 说明:p为类型为int型
数组的指针。数组的指针指向数组长度为4的数组。 - 含义: 一个指向M个整型元素一维数组指针。
5、指针数组
- int *p[3]
- 优先级:
()>[]>* - 说明:p是由三个指针变量构成的
数组。简称指针数组,即这是一个指针的数组,里面的每一个元素都是指针(存放的是地址)。
5、函数指针
- int (*p)();
- 说明:p是返回值为整型
函数的指针
6、指针函数
- int *p();
- 说明:p是返回值为整型
指针的函数
边栏推荐
- Qprocess of QT
- How to write a string field in MySQL if its value is not empty?
- Google Play应用商店可能会删除应用权限概述 转而使用新的数据安全信息组合
- Support for multiple devices in (ghost engine)
- 【虹科】激光雷达安全系统:让世界更安全
- vscode下载历史版本
- Distributed transaction reliable message final consistency solution
- Hausdorff loss function for semantic segmentation
- SQL优化
- Programming in the novel [serial 14] the moon bends in the yuan universe
猜你喜欢

Case sharing | build a one-stop data development platform for hehe information based on linkis+dss

【C语言-自定义类型】还能这样整?

Microservice splitting for stand-alone projects

简易的第三方组件日志脱敏

一文,教你实现单点登录

Redis
![[Hongke] Introduction to genicam protocol](/img/a5/91a1d24a47ea2e3265530778d6fc1f.png)
[Hongke] Introduction to genicam protocol

shell-笔记

数据湖(二十):Flink兼容Iceberg目前不足和Iceberg与Hudi对比

焱融科技入选北京市 2022 年度“专精特新”,领航混合云文件存储
随机推荐
Etcd database source code analysis -- etcdserver bootstrap recover store from snapshot
2、 Pinda general permission system__ Project construction
Development utility
Express
codeforces每日5题(均1500)-第十七天
2022 Guangdong Provincial Safety Officer a certificate, the third batch (main person in charge) exercise questions and mock examination
Log desensitization - Reference
2022年P气瓶充装考试练习题模拟考试平台操作
Authing 实践|制造业身份认证统一管理解决方案
【CTF】pwn2_ sctf_ two thousand and sixteen
vscode下载历史版本
2022T电梯修理考试题库及答案
QT串口通信
It's also very difficult. I'm not only tired of writing by myself
MySQL视图
第六天训练
QR decomposition for matrix inversion -- C engineering implementation
小说里的编程 【连载之十一】元宇宙里月亮弯弯
树状数组
第五天训练