C语言----字符数组&&指针

简介: C语言----字符数组&&指针

1.char arr[] = {'a','b','c','d','e','f'};

sizeof分析类型就可以计算所占的内存空间的大小;

(1)printf("%d\n", sizeof(arr));

数组名单独放进里面,计算整个数组大小,所以是6字节;

(2)printf("%d\n", sizeof(arr+0));

第一个元素地址,是地址就是4或8,不会因为 是char类型而想成是1,因为无论是什么类型,地址的大小是不变的,就是4或8;

(3)printf("%d\n", sizeof(*arr));

首元素地址,解引用后是第一个元素,char类型,1字节;

(4)printf("%d\n", sizeof(arr[1]));

第二个元素,类型char,大小是1字节;

(5)printf("%d\n", sizeof(&arr));

数组地址,4或8字节;

(6)printf("%d\n", sizeof(&arr+1));

还是地址,虽然跳过整个数组,是地址就是4或8;

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

第二个元素地址,4或8字节;

-----------------------------------------------------------------------------------------------------------------

2.char arr[] = {'a','b','c','d','e','f'};

(1)printf("%d\n", strlen(arr));

求字符串的长度,统计字符串斜杠0之前的字符个数,字符数组里面无斜杠0,会一直向后面找,答案是随机值;

(2)printf("%d\n", strlen(arr+0));

这个还是从第一个向后找,所以是随机值;

(3)printf("%d\n", strlen(*arr));

strlen参数是地址,根据提供的地址向后找,*arr是首元素解引用就是字符a,ASCII值是97,会从97地址处开始找,所以是非法访问,非法访问97地址处的数值;

(4)printf("%d\n", strlen(arr[1]));

这个传递的参数同上,是98地址,非法访问;

(5)printf("%d\n", strlen(&arr));

chat(*)[6]转换成char*类型,数组的地址,和首个元素地址值相同,依然是从第一个元素位置开始找,所以是随机值;

(6)printf("%d\n", strlen(&arr+1));

跳过整个数组,还是地址,从最后开始找,是随机值;

(7)printf("%d\n", strlen(&arr[0]+1));

从第二个元素的地址处往后找,是随机值;

这些随机值不是没有规律的,他们之间相差的是对应的字符的个数;

---------------------------------------------------------------------------------------------------------------------------------

3.char arr[] = "abcdef";

这里的末尾有了斜杠0

(1)printf("%d\n", sizeof(arr));

7个字节;

----------------------------------------

(2)printf("%d\n", sizeof(arr+0));

首元素地址,4/8

---------------------------------------------

(3)printf("%d\n", sizeof(*arr));

首个元素,1字节;

--------------------------------------------

(4)printf("%d\n", sizeof(arr[1]));

第二个元素,1字节;

------------------------------------------------

(5)printf("%d\n", sizeof(&arr));

整个数组地址,4/8;

----------------------------------------------

(6)printf("%d\n", sizeof(&arr+1));

还是地址,4/8;

----------------------------------------------

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

还是地址,4/8;

---------------------------------------------------------------------------------------------------------------------------------

4.char arr[] = "abcdef";

printf("%d\n", strlen(arr));

6字节;

-------------------------------------

printf("%d\n", strlen(arr+0));

6字节;

--------------------------------------

printf("%d\n", strlen(*arr));

第一个元素,是字符a,这个是错误;

----------------------------------------

printf("%d\n", strlen(arr[1]));

第二个元素,字符b,这个是错误;

---------------------------------------------

printf("%d\n", strlen(&arr));

数组地址,6字节;

-------------------------------------------

printf("%d\n", strlen(&arr+1));

跳过整个数组,也跳过了斜杠0,是随机值;

-------------------------------------------

printf("%d\n", strlen(&arr[0]+1));

跳过第一个字符,5字节;

--------------------------------------------------------------------------------------------------------------------------------

5.char *p = "abcdef";

这里p指向第一个元素地址

printf("%d\n", sizeof(p));

是地址,就是4/8字节;

------------------------------------

printf("%d\n", sizeof(p+1));

指向b字符,还是地址,是4/8字节;

-----------------------------------

printf("%d\n", sizeof(*p));

访问a字符,大小是1字节;

------------------------------------

printf("%d\n", sizeof(p[0]));

*(p+0)相当于*p,是1字节

------------------------------------

printf("%d\n", sizeof(&p));

是地址,&p是二级指针,是p所在处的地址,地址是4/8;

--------------------------------------

printf("%d\n", sizeof(&p+1));

还是地址,是4/8字节;

--------------------------------------

printf("%d\n", sizeof(&p[0]+1));

指向字符b,是地址,是4/8字节;

---------------------------------------------------------------------------------------------------------------------------

6.char *p = "abcdef";

printf("%d\n", strlen(p));

从a开始,6字节;

-----------------------------------

printf("%d\n", strlen(p+1));

从b开始,5字节;

-----------------------------------

printf("%d\n", strlen(*p));

非法访问,97地址处的内存,错误的;

----------------------------------------------

printf("%d\n", strlen(p[0]));

*(p+0),还是a,是错误的;

---------------------------------------------

printf("%d\n", strlen(&p));

是随机值;

----------------------------------------------

printf("%d\n", strlen(&p+1));

也是随机值;

---------------------------------------------------

printf("%d\n", strlen(&p[0]+1));

从b开始找,所以是4字节;

相关文章
|
1月前
|
存储 NoSQL 编译器
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
指针是一个变量,它存储另一个变量的内存地址。换句话说,指针“指向”存储在内存中的某个数据。
97 3
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
|
1月前
|
存储 算法 C语言
【C语言】字符常量详解
字符常量是C语言中处理字符数据的重要工具。通过单引号括起一个字符,我们可以方便地使用字符常量进行字符判断、字符运算和字符串处理等操作。理解字符常量的表示方法、使用场景和ASCII码对应关系,对于编写高效的C语言程序至关重要。
181 11
|
1月前
|
存储 编译器 C语言
【C语言】指针大小知多少 ?一场探寻C语言深处的冒险 !
在C语言中,指针的大小(即指针变量占用的内存大小)是由计算机的体系结构(例如32位还是64位)和编译器决定的。
62 9
|
1月前
|
安全 程序员 C语言
【C语言】指针的爱恨纠葛:常量指针vs指向常量的指针
在C语言中,“常量指针”和“指向常量的指针”是两个重要的指针概念。它们在控制指针的行为和数据的可修改性方面发挥着关键作用。理解这两个概念有助于编写更安全、有效的代码。本文将深入探讨这两个概念,包括定义、语法、实际应用、复杂示例、最佳实践以及常见问题。
49 7
|
1月前
|
存储 C语言 开发者
【C语言】格式化输出占位符及其标志字符详解(基于ISO/IEC 9899:2024)
在C语言中,格式化输出通过 `printf` 函数等格式化输出函数来实现。格式说明符(占位符)定义了数据的输出方式,标准ISO/IEC 9899:2024(C23)对这些格式说明符进行了详细规定。本文将详细讲解格式说明符的组成部分,包括标志字符、宽度、精度、长度修饰符和类型字符,并适当增加表格说明。
46 6
|
1月前
|
传感器 算法 安全
【C语言】两个数组比较详解
比较两个数组在C语言中有多种实现方法,选择合适的方法取决于具体的应用场景和性能要求。从逐元素比较到使用`memcmp`函数,再到指针优化,每种方法都有其优点和适用范围。在嵌入式系统中,考虑性能和资源限制尤为重要。通过合理选择和优化,可以有效提高程序的运行效率和可靠性。
121 6
|
2月前
|
存储 缓存 算法
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式
在C语言中,数据结构是构建高效程序的基石。本文探讨了数组、链表、栈、队列、树和图等常见数据结构的特点、应用及实现方式,强调了合理选择数据结构的重要性,并通过案例分析展示了其在实际项目中的应用,旨在帮助读者提升编程能力。
79 5
|
2月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
2月前
|
程序员 C语言
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门。本文深入探讨了指针的基本概念、声明方式、动态内存分配、函数参数传递、指针运算及与数组和函数的关系,强调了正确使用指针的重要性,并鼓励读者通过实践掌握这一关键技能。
47 1
|
3天前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
26 15