引入:
数据读取–>必须知道其地址–>而指针则用来存放数据的地址
指针是什么?
总结:指针就是变量,用来存放地址的变量。(存放在指针中的值都被当成地址处理)
一级指针
a.作用:用于存放地址
b.相关性质:
是一个变量
是变量就必须开辟空间
空间额开辟是在内存进行的
内存则被按字节分为连续的区域
每个字节都有他自己的编址(如图)
二级指针
上边在介绍以及指针时有提到:指针也是变量,而是变量就必须在内存开辟空间,因此指针也有自己的地址,在这里用于存储指针地址的变量则被称为了二级指针。
指针和指针类型
A.上边总结中提到,指针也是变量,是变量就会在栈上开辟空间,就会有自己类型。
B.那如何给他们定义相应的类型呢?? ?(请看如下代码)
char *pc = NULL;
int *pi = NULL;
short *ps = NULL;
long *pl = NULL;
float *pf = NULL;
double *pd = NULL;
这里可以看到,指针的定义方式是: type + * 。 其实: char* 类型的指针是为了存放 char 类型变量的地址。 short* 类型的指针是为了存放 short 类型变量的地址。 int* 类型的指针是为了存放 int 类型变量的地址。
指针类型的意义
指针的类型决定了指针向前或者向后走一步有多大(距离)
A.指针与整数加减
指针-+整数
int n = 10;
char *pc = (char*)&n
printf("%p\n", pc+1);
//%p:用于打印地址,而此处指针pc的地址加了一个char的大小1。
这里的向前向后指的是指针加减后的结果,指针加一,减一指的是加上或减去本身类型的大小
指针与指针相减
指针-指针
这里指针相减可以计算出它们两个指针之间的元素个数,因此运算可用于计算字符串的长度,从而模拟strlen()函数的实现。
模拟strlen()函数的实现
int my_strlen(char *s)
{
char *p = s;
while(*p != '\0' )
p++;
return p-s;
}
指针的关系运算
这里指针的关系运算可用于对数组元素的初始化,或者赋值,例如下边的代码用它完成啦对数组的赋值
for(vp = &values[N_VALUES-1]; vp >= &values[0];vp--)
{
*vp = 0;
}
指针和数组
int main
{
int* p;
assert(p!=NULL);
int arr[10]={1,2,3,4,5,6,7,9,10};
p=arr;
printf("p+1=%p",p+1);
printf("&arr[1]",&arr[1];
}
结果:p+1=&arr[1]显而易见p+i与arr[i]相等
因此:我们可以通过p+i访问数组arr的地址,用解引用*(p+i)访问数组元素arr[i]
指针数组
既存放指针的数组
例如:
char* arr3[3];//根据优先级,先与中括号结合,再与*结合,arr先是数组,后是指针,因此叫做指针数组。
加粗样式