数组名复习

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

}

相关推荐
Samuel-Gyx6 分钟前
数据结构--二叉树构造与遍历顺序的相互转化
数据结构
努力学算法的蒟蒻11 分钟前
day17(11.18)——leetcode面试经典150
算法·leetcode·面试
缘友一世17 分钟前
模型微调DPO算法原理深入学习和理解
算法·模型微调·dpo
未若君雅裁22 分钟前
斐波那契数列 - 动态规划实现 详解笔记
java·数据结构·笔记·算法·动态规划·代理模式
断剑zou天涯22 分钟前
【算法笔记】从暴力递归到动态规划(三)
java·算法·动态规划
RQ_ghylls22 分钟前
2.excel每3行计算一个均值,将高于均值的单元格设置背景红色
算法·均值算法·word·excel
断剑zou天涯26 分钟前
【算法笔记】从暴力递归到动态规划(一)
java·算法·动态规划
不爱编程爱睡觉29 分钟前
代码随想录算法训练营第二十八天 | 动态规划算法基础、 LeetCode509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法·leetcode·动态规划·代码随想录
这张生成的图像能检测吗1 小时前
(论文速读)多任务深度学习框架下基于Lamb波的多损伤数据集构建与量化算法
人工智能·深度学习·算法·数据集·结构健康监测
晨非辰4 小时前
数据结构排序系列指南:从O(n²)到O(n),计数排序如何实现线性时间复杂度
运维·数据结构·c++·人工智能·后端·深度学习·排序算法