32位平台下指针变量⼤⼩是4个字节
64位平台下,指针变量⼤⼩是8个字节
和类型是⽆关的
指针的类型决定了,对指针解引⽤的时候有多⼤的权限(⼀次能操作⼏个字节)。
⽐如: char* 的指针解引⽤就只能访问⼀个字节,⽽ int* 的指针的解引⽤就能访问四个字节。
结论:指针的类型决定了指针向前或者向后⾛⼀步有多⼤(距离)。
int main()
{
int n = 0x11223344;
int* m = &n;
char* x = &n;
printf("%p\n",m);
printf("%p\n", m + 1);
printf("%p\n", x);
printf("%p\n", x+1);
return 0;
}
自己制作求字符串长度的函数
方法一
int my_string(char* set)
{
int count = 0;
while (*set != '\0')
{
count++;
set++;
}
return count;
}
int main()
{
char arr[] = "zbcdef";
int i=my_string(arr);
printf("%d", i);
return 0;
}
方法二
int my_string(char* set)
{
char*mox = set;
while (*set != '\0')
{
set++;
}
return set - mox;
}
int main()
{
char arr[] = "zbcdef";
int i=my_string(arr);
printf("%d", i);
return 0;
}
利用指针打印数组
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int sz = sizeof(arr) / sizeof(arr[0]);
int* p = arr;
while (p<arr+sz)
{
printf("%d", *p);
p++;
}
return 0;
}
p指的是地址
*p指的是指向的内容
野指针
产生原因
1.指针未初始化
#include <stdio.h>
int main()
{
int *p; //局部变量指针未初始化,默认为随机值
*p = 20;
return 0;
}
2.指针越界访问
#include <stdio.h>
int main()
{
int arr[10] = {0};
int *p = &arr[0];
int i = 0;
for(i=0; i<=11; i++)
{
//当指针指向的范围超出数组arr的范围时,p就是野指针
*(p++) = i;
}
return 0;
}
3.指针指向的空间已经释放,仍然使用
#include <stdio.h>
int* test()
{
int n = 100;
return &n;
}//n出去的时候已经销毁,下方仍然使用
int main()
{
int*p = test();
printf("%d\n", *p);
return 0;
}