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

相关推荐
Buleall5 分钟前
期末考学C
java·开发语言
重生之绝世牛码7 分钟前
Java设计模式 —— 【结构型模式】外观模式详解
java·大数据·开发语言·设计模式·设计原则·外观模式
小蜗牛慢慢爬行13 分钟前
有关异步场景的 10 大 Spring Boot 面试问题
java·开发语言·网络·spring boot·后端·spring·面试
荒古前19 分钟前
龟兔赛跑 PTA
c语言·算法
Colinnian23 分钟前
Codeforces Round 994 (Div. 2)-D题
算法·动态规划
Algorithm157623 分钟前
云原生相关的 Go 语言工程师技术路线(含博客网址导航)
开发语言·云原生·golang
用户00993831430129 分钟前
代码随想录算法训练营第十三天 | 二叉树part01
数据结构·算法
shinelord明32 分钟前
【再谈设计模式】享元模式~对象共享的优化妙手
开发语言·数据结构·算法·设计模式·软件工程
新手小袁_J38 分钟前
JDK11下载安装和配置超详细过程
java·spring cloud·jdk·maven·mybatis·jdk11