C语言数组和指针笔试题(二)(一定要看)

目录

字符数组二

c 复制代码
char arr[] = {'a','b','c','d','e','f'}
1:printf("%d\n", strlen(arr));
2:printf("%d\n", strlen(arr+0));
3:printf("%d\n", strlen(*arr));
4:printf("%d\n", strlen(arr[1]));
5:printf("%d\n", strlen(&arr));
6;printf("%d\n", strlen(&arr+1));
7;printf("%d\n", strlen(&arr[0]+1));

例题1

c 复制代码
char arr[] = {'a','b','c','d','e',}
printf("%d\n", strlen(arr));

这里的arr中存放的是字符,而strlen是求的字符串长度,也就是说需要遇见\0才会停止,但是数组中并没有\0,因此会出现越界访问,直到找到\0为止,所以最后的结果会>=6

例题2

c 复制代码
char arr[] = {'a','b','c','d','e',}
printf("%d\n", strlen(arr+0));

根据上一篇博客,arr+0就是&arr[0],所以是字符a的地址,但是仍然不知道\0在哪,所以是随机值

例题3

c 复制代码
char arr[] = {'a','b','c','d','e',}
printf("%d\n", strlen(*arr));

*arr是对第一个数组元素解引用,就是字符a,所以就没有\0,这段代码可能会报错

例题4

c 复制代码
char arr[] = {'a','b','c','d','e',}
printf("%d\n", strlen(arr[1]));

arr[1]是指的第二个元素,是字符b,和例题3一样,找不到\0,可能会报错

例题5

c 复制代码
char arr[] = {'a','b','c','d','e',}
printf("%d\n", strlen(&arr));

&arr是整个数组的地址,但是不知道\0在哪,所以是随机值

例题6

c 复制代码
char arr[] = {'a','b','c','d','e',}
printf("%d\n", strlen(&arr+1));

&arr+1是跳过整个数组,在上一篇博客有讲过,其实意思和上一题一样,是随机值

例题7

c 复制代码
char arr[] = {'a','b','c','d','e',}
printf("%d\n", strlen(&arr[0]+1));

&arr[0]+1就是&arr[1]也是地址,不知道\0在哪,所以是随机值

总结

对于strlen而言必须要遇到\0才能停止,所以如果我们找不到\0(arr[]={'a','b'},strlen(arr[0]))像这样的就是找不到,因为已经确定strlen括号里是一个数组的元素,因为是字符a,并不是\0,所以会找不到

但是如果strlen括号里的是一个地址,strlen会往这个地址后面找,直到找到\0为止

字符数组三

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr));
2:printf("%d\n", sizeof(arr+0));
3:printf("%d\n", sizeof(*arr));
4:printf("%d\n", sizeof(arr[1]));
5:printf("%d\n", sizeof(&arr));
6:printf("%d\n", sizeof(&arr+1));
7:printf("%d\n", sizeof(&arr[0]+1));

例题1

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr));

这里先对数组中的字符串说明一下

我们可以看到字符串其实也可以用数组表示,字符串我们可以理解为由多个字符组成,'a','b','c','d','e','f','\0',arr[0]表示的字符串中的第一个元素'a',arr[1]表示字符串中第二个元素'b'...

因此sizeof[arr]其实可以理解为整个字符串中的所有字符大小,所以最后的结果是7

例题2

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr+0));

这里的arr+0=&arr[0],是一个地址,sizeof(地址)结果是4或者8

例题3

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(*arr));

arr中的arr是字符串中首元素的地址,所以arr是对字符串首元素解引用,就是字符'a',所以sizeof求的大小就是字符的大小,所以是1

例题4

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(arr[1]));

arr[1]是指的字符串中的字符'b',所以sizeof求的是字符'b'的大小,因为是char类型,所以结果是1

例题5

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(&arr));

&arr是地址,所以结果是4或者8

例题6

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(&arr+1));

&arr+1也是一个地址,所以结果是4或者8

例题7

c 复制代码
char arr[] = "abcdef";
1:printf("%d\n", sizeof(&arr[0]+1));

&arr[0]+1=&arr[1],是地址,所以几个是4或者8

相关推荐
橙几几秒前
击败了90%的解法?Two Sum 从 O(n²) 到 O(n) 的优化之路
算法
大葱白菜2 分钟前
Java Set 集合详解:从基础语法到实战应用,彻底掌握去重与唯一性集合
java·后端
大葱白菜3 分钟前
Java Map 集合详解:从基础语法到实战应用,彻底掌握键值对数据结构
java·后端
添乱3 分钟前
「Java案例」判断是否是闰年的方法
java
FG.7 分钟前
Day22
java·面试
apihz8 分钟前
域名WHOIS信息查询免费API使用指南
android·开发语言·数据库·网络协议·tcp/ip
菜鸟的迷茫9 分钟前
Redis 缓存雪崩、穿透、击穿面试题深度解析与 Spring Boot 实战代码示例
java
叶子爱分享14 分钟前
经典排序算法之归并排序(Merge Sort)
算法·排序算法
珹洺20 分钟前
C++算法竞赛篇:DevC++ 如何进行debug调试
java·c++·算法
coding随想21 分钟前
掌控网页的魔法之书:JavaScript DOM的奇幻之旅
开发语言·javascript·ecmascript