数组名复习

#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(arr[1]));//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(&arr[0] + 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(arr[1]));//非法访问(野指针)

//跟上面情况一样

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

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

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

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

return 0;

}

相关推荐
Yhame.12 分钟前
【使用层次序列构建二叉树(数据结构C)】
c语言·开发语言·数据结构
雾月5537 分钟前
LeetCode 1292 元素和小于等于阈值的正方形的最大边长
java·数据结构·算法·leetcode·职场和发展
Pasregret1 小时前
访问者模式:分离数据结构与操作的设计模式
数据结构·设计模式·访问者模式
知来者逆2 小时前
计算机视觉——速度与精度的完美结合的实时目标检测算法RF-DETR详解
图像处理·人工智能·深度学习·算法·目标检测·计算机视觉·rf-detr
阿让啊2 小时前
C语言中操作字节的某一位
c语言·开发语言·数据结构·单片机·算法
এ᭄画画的北北2 小时前
力扣-160.相交链表
算法·leetcode·链表
草莓啵啵~3 小时前
搜索二叉树-key的搜索模型
数据结构·c++
爱研究的小陈3 小时前
Day 3:数学基础回顾——线性代数与概率论在AI中的核心作用
算法
渭雨轻尘_学习计算机ing3 小时前
二叉树的最大宽度计算
算法·面试
丶Darling.4 小时前
26考研 | 王道 | 数据结构 | 第八章 排序
数据结构·考研·排序算法