数组名复习

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

}

相关推荐
橘颂TA4 分钟前
【剑斩OFFER】算法的暴力美学——LeetCode 733 题:图像渲染
算法·leetcode·职场和发展
不穿格子的程序员7 分钟前
从零开始写算法——回溯篇2:电话号码的字母组合 + 组合总和
算法·深度优先·回溯
仍然.11 分钟前
JavaDataStructure---二叉搜索树,哈希表,Map和Set
数据结构·散列表
持梦远方39 分钟前
算法剖析1:摩尔投票算法 ——寻找出现次数超过一半的数
c++·算法·摩尔投票算法
程序员-King.1 小时前
链表——算法总结与新手教学指南
数据结构·算法·链表
Ulyanov1 小时前
战场地形生成与多源数据集成
开发语言·python·算法·tkinter·pyside·pyvista·gui开发
FMRbpm2 小时前
树的练习6--------938.二叉搜索树的范围和
数据结构·c++·算法·leetcode·职场和发展·新手入门
wubba lubba dub dub7502 小时前
第三十三周 学习周报
学习·算法·机器学习
C+-C资深大佬2 小时前
C++数据类型
开发语言·c++·算法
多米Domi0112 小时前
0x3f 第35天 电脑硬盘坏了 +二叉树直径,将有序数组转换为二叉搜索树
java·数据结构·python·算法·leetcode·链表