指针和数组试题解析(3)字符数组部分续集

对于指针和数组的关系!想必到目前为止,大家都已经了解差不多了!即有指针数组,数组指针,还有函数指针数组……一系列复杂关系!所以,笔者吸取学长经验,私底下窃取了一些材料,再加上仔细地思考分析,所以,决定系统的发一套指针和数组试题解析供大家分析理解!!虽然内容不是很多,但是凝聚下来的便都是精华!也是笔者精心打造,请各位老铁耐心欣赏一下!!顺便动用一下发财的小手,一键三连呀!!

言归正传!下面请看笔者代码+解析:

对于笔者的此篇博文,需要结合上篇文章,对比起来才更会有效果!否则,将会影响不大!!链接为:指针和数组试题解析(2)字符数组部分_念君思宁的博客-CSDN博客  请感兴趣的读者进行欣赏!!

下面请看笔者代码:

#include <stdio.h>
#include <string.h>
int main()
{
	char arr[] = { 'a','b','c','d','e','f' };

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

	return 0;
}

注意,笔者的代码是在vs2022 的x86环境下进行演示的!请注意细节,若是在vs2022的x64环境下,将会出现不一样的结果!但那个结果也是正确的!

 若是有老铁能直接看懂,并且能够跟答案对上号,那么这篇博客,这位老铁就没有看的必要了,下面内容主要是对上面的代码的讲解!并不做其他的内容!但若是有兴趣,可以进一步欣赏!
下面进入讲解部分

对于字符数组:char arr[] = { 'a','b','c','d','e','f' };  数组有6个元素!每个元素都为: char 类型,所占1个字节!

1. strlen(arr)  :  arr是数组名,但是没有放在 strlen内部,也没有进行&arr(取地址操作)!即:arr就是首元素的地址! strlen得到arr以后,从arr数组首元素的地方开始计算字符串的长度,一直到遇见"\0'结束!但是在数组arr中,并没有‘\0’,至于arr数组的后面是否有'\0',在什么位置,是不确定的,所以在'\0'之前,出现了多少字符是随机的!!

2.strlen(arr+0)  : arr是数组的首元素的地址!arr+0也是首元素的地址!思路跟第一个:strlen(arr)是一个道理,可以参考第一个解析!所以是个随机值!

3.strlen(*arr)  : arr是数组的首元素的地址!*arr是得到首元素‘a',而'a'的ASCII码值为:97;所以strlen 就把:'a'的ASCII码值为:97 ;当作了地址!所以会出现错误!!

4.strlen(arr[1])  : 跟上面的第三个(strlen(*arr))是一样的道理!而arr[1]是元素'b':而'b'的ASCII码值为: 98,也不是个地址!所以会出现错误!

5.strlen(&arr)  : 跟第一个的分析情况一样(strlen(arr) )!&arr取出的是数组的地址!数组的地址是指向数组的起始位置!因此,和第一个(strlen(*arr))的情况一样!依次往后计算,一直到'\0'之前的元素个数,所以也是个随机值!

6.strlen(&arr+1)  : 在这里面arr没有放在sizeof内部,也没有单独的被&arr,所以:&arr是数组的首元素的地址!&arr+1跳出了整个数组!指向数组后面的部分!然后依次往后计算,一直到'\0'之前的元素个数,所以也是个随机值!

7.strlen(&arr[0] + 1)  : 对于&arr[0] 取出的是数组arr第一个元素的位置;&arr[0] + 1  :跳过一个字节,指向第二个元素元素:'b'的位置!然后依次往后计算,一直到'\0'之前的元素个数,所以也是个随机值!!

上述代码的运行结构为:

之前笔者已经讲解过不少的知识了!!下面到了考一考时间!请仔细分析哟,这次笔者不在进行解析!

话不多说,请看笔者代码:

代码段1:

#include <stdio.h>
int main()
{
	char arr[] = "abcdef";

	printf("%d\n", sizeof(arr));   //7
	printf("%d\n", sizeof(arr+0));  //4
	printf("%d\n", sizeof(*arr));    //1
	printf("%d\n", sizeof(arr[1]));   //1
	printf("%d\n", sizeof(&arr));    //4
	printf("%d\n", sizeof(&arr+1));   //4
	printf("%d\n", sizeof(&arr[0] + 1));   //4

	return 0;
}

代码段2:

#include <string.h>
#include <stdio.h>
int main()
{
	char arr[] = "abcdef";

	printf("%d\n", strlen(arr));      //6
	printf("%d\n", strlen(arr + 0));  //6
	printf("%d\n", strlen(*arr));    //错误
	printf("%d\n", strlen(arr[1]));   //错误
	printf("%d\n", strlen(&arr));     //6
	printf("%d\n", strlen(&arr + 1));  //随机值
	printf("%d\n", strlen(&arr[0] + 1));   //5

	return 0;
}

上面两个思考题,请读者仔细思考一下!若有疑问,请及时电联笔者!!受宠若惊!

 本篇文章,大致到此已经结束,有意者请与笔者私聊哟!!感概万千!!


 

猜你喜欢

转载自blog.csdn.net/weixin_64308540/article/details/126915272