数组名复习

#define _CRT_SECURE_NO_WARNINGS

#include <stdio.h>

/*

int main()

{

char arr\[\] = { 'a','b','c','d','e','f' };

printf("%d\n", sizeof(arr));//6

//sizeof(数组名),计算整个数组的大小

printf("%d\n", sizeof(arr + 0));//4或8

//是数组首元素的地址,是地址大小就是4或8个字节

printf("%d\n", sizeof(*arr));//1

//*arr就是数组的首元素,大小是1字节

printf("%d\n", sizeof(arr1));//1

//第二个元素大小是1个字节

printf("%d\n", sizeof(&arr));//4或8

//取出的是数组的地址,是地址就是4或8个字节

printf("%d\n", sizeof(&arr + 1));//4或8

//&arr+1还是地址,是跳过整个数组后的地址

printf("%d\n", sizeof(&arr0 + 1));//4或8

//第二个元素的地址,是地址就是4或8

return 0;

}

*/

//strlen计算字符串长度,遇到\0才停止

#include <string>

int main()

{

char arr\[\] = { 'a','b','c','d','e','f' };

printf("%d\n", strlen(arr));//随机值

//arr是首元素地址,从首元素地址向后数,直到遇到\0停止

printf("%d\n", strlen(arr + 0));//随机值

//首元素地址+0还是首元素地址,跟上面一样

printf("%d\n", strlen(*arr));//非法访问(野指针)

//strlen默认访问地址

//*arr相当于'a','a'的ASCII码是97,把97作为地址编号传过去是非法的

//因为内存要先开辟地址才能使用

printf("%d\n", strlen(arr1));//非法访问(野指针)

//跟上面情况一样

printf("%d\n", strlen(&arr));//随机值

//&arr是数组的地址,数组的地址也是从首元素开始数

printf("%d\n", strlen(&arr + 1));//随机值-6

printf("%d\n", strlen(&arr0 + 1));//随机值-1

return 0;

}

相关推荐
JieE2123 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2121 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack201 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树1 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2122 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2122 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言