1、指针定义
(1)普通指针 int val =0; int* p = &val;
(2)数组指针: int arr[3] ; int (*p1)[3] =& arr; p1+1 能力 偏移量12个字节,因为此时的类型已经改变,int为4字节,arr[3],所以p1+1相当于移动一个格子,而这一个格子的字节应为4×3=12字节,所以其偏移量为12字节。
(3)函数指针: int add (int a, int b) ; int (*p)(int ,int )= add;
add(1,2);
p(1.2);定义一个函数指针add,可以用p修改调用,在后续的项目编写里,这样做会极其方便,可以只需定义一次,后面直接修改调用。
2、普通指针使用 int val=0;int*p = &val; *p = 1;对int* p 未进行初始化时,会成为野指针,在后面调用时程序可能会崩。
数组指针: int (*p)[3];
使用方法:
3、判断大小端问题
下面是数据存储模式,分为两种:小端存储和大端存储
我们通常采用指针验证法进行判断大小端问题,代码如下:
运行结果如下:
所以vs采用小端存储。
4、指针+1的能力
例如我们定义一个int*p,p+1就是指偏移量,p的数据类型为int,所以p+1就偏移4个字节;
指针-指针就是指两个指针之间相差的格子数。
5、指针数组
定义一堆字符串常量,例如:const char* arr[] = "abc" ;const是用来定义常变量的。
6、const和指针结合