一 指针和指针类型
指针用来存储地址
int a=10; int* pa=&a; //pa是指针变量,int* 是pa的类型
指针类型决定了在解引用时一次能访问几个字节(指针的权限)
int* -->4
char* -->2
couble -->8
指针类型决定了指针向前或向后走一步,走了多远距离(单位是字节)
二 解引用
用指针打印数组
#includeint main() { int arr[10]={0}; int* p=arr; int i=0; for(i=0;i<10;i++) { *(p+i)=i+1; } //倒着打印 int* q=&arr[9]; for(i=0;i<10;i++) { printf("%d ",*q); q--; } return 0; }
三 野指针
野指针成因
1 指针未初始化
int* p;//p是野指针 *p=20;
2 指针越界访问
int arr[10]={0};
int* p=arr;
for(i=0;i<=10;i++)
{
*p=i;
p++;
}
3 指针指向的空间释放了
#includeint* test() { int a=100; return &a; } int main() { int* p=test(); printf("%d",*p); return 0; }
四 指针运算
1 指针+-整数
#includeint main() { int arr[10]={0}; int* p=arr; int i=0; int sz=sizeof(arr)/sizeof(arr[0]); for(i=0;i
2 指针-指针
#includeint main() { int arr[10]={0}; printf("%dn",&arr[9]-&arr[0]); printf("%dn",&arr[0]-&arr[9]); return 0; } 地址相减的绝对值得到的是之间的元素个数
指针-指针的前提是:两个指针指向同一个空间
求字符串长度方法(指针-指针实现)
int my_strlen(char* s) { char* start=s; while(*s!=' ') { s++; } return s-start; }3 指针的关系运算
#include#define N_VALUES 5 int main() { float values[N_VALUES]; float* vp; for(vp=&values[N_VALUES];vp>&values[0];) { *vp=0; vp--; } } 标准规定:允许指向数组元素的指针与指向数组最后一个元素后面的那个内存位置的指针比较,但不允许与指向数组第一个元素之前的那个内存位置的指针比较
五 二级指针
int a=10; int* pa=&a; int** ppa=&pa;//ppa就是一个二级指针 //多级指针同样存在



