一些易错,易混淆习题

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;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值