指针以字节为单位;

指针类型决定了解引用时能访问的空间的大小;也决定了指针的步长(指针+1走多远)
int* test()
{
int a = 10;//野指针
return &a;
}
int main(){
int* p = test();
//test函数里的a是局部变量,出函数时,储存变量的空间已经还给操作系统了
printf("%d\n",*p);
//此时通过解引用不能再访问到a;
}
如何规避野指针呢?
int arr[5] = {0,1, 2, 3, 4};
int* p = arr;
int i = 0;
for(i=0; i<5; i++)
{
//printf("%d ",*p);
//p++;
printf("%d ",*p++);//以上两种写法相同
}
得到的是中间元素的个数,可以用来求字符串的长度
int my_strlen(char* arr)
{
char* start = arr;
char* end = arr;
while(*end != '\0')
{
end++;
}
return end - start;
}
其实就是指针比较大小。实际在绝大部分的编译器上是可以顺利完成任务的,然而我们还是应该避免这样写,因为标准并不保证它可行。
float values[5];
float *vp;
int i = 0;
for (vp = &values[0]; vp < &values[5];)
{
*vp++ = 0;
}
存放指针的数组
int a; int b; int c;
int* arr[3] = {&a,&b,&c};