int mian()
{
char arr[] = { 'a', 'b', 'c', 'd', 'e', 'f' };
printf("%d\n", arr + 0);
//arr在这里不是单独存在的,所以不是表示整个数组,而是首元素的地址,首元素的地址加0还是首元素的地址,地址的大小是4 或 8 个字节
printf("%d\n", *arr);
//arr不是单独存在的,所以不是表示整个数组,对首元素的地址解引用得到首元素,大小为一个字节
printf("%d\n", strlen(*arr));
//因为 strlen(const char* p),返回类型为size_t(unsigned int) 类型,所以不管什么类型的数据放入strlen中都会被转化成char* 类型的指针,在这里*arr就是字符a ASCLL值为97,在这里strlen就会把97当作一个地址,但97这个地址并没有开辟,所以是野指针,系统会报错
return 0;
}
int main()
{
char* p = "abcdef";//p里面存放的是首元素 a 的地址
printf("%d\n", sizeof(*p));
//对a的地址解引用得到字符a,大小为1个字节
printf("%d\n", strlen(p + 1));
//p为首元素的地址,char*类型,+1跳过一个字符,指向字符b,所以p+1是b的地址,strlen(p+1)为5
printf("%d\n", strlen(&p));
//&p是首元素的地址的地址,strlen从p开始往后遍历,而不是a了,所以不知道什么时候遇到\0,为随机值
return 0;
}
int main()
{
int arr[3][4] = { 0 };
printf("%d\n", sizeof(arr[0]));
//这里把arr[0]理解为二维数组中第一个一维数组的数组名,结果就是16
printf("%d\n", sizeof(arr + 1));
//这里arr是二位数组第一行的地址(第一个一维数组的地址),而不是数组名。+1就是第二行的地址,所以是4或8
printf("%d\n", sizeof(*(arr + 1)));
//对第二行的地址进行解引用,得到的是整个第二行,所以是16
printf("%d\n", sizeof(*(&arr[0] + 1)));
//arr[0]是第一行的数组名,&arr[0]就是第一行的地址,+1就是第二行的地址,然后解引用得到第二行,结果是16
printf("%d\n", sizeof(arr[3]));
//这里并不会越界访问,因为sizeof只关注它的大小,而不关注内容,sizeof(arr[3])就等价于sizeof(arr[0])
//类比于sizeof(int)等价于sizeof(a) (int a = 10),只要知道a的类型,我就可以知道a的大小
return 0;
}