指针和数组试题解析(2)字符数组部分

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 指针和数组试题解析(2)字符数组部分

谨记:对于字符数组,我们要跟字符串区分开!!

下面进入笔者的指针和数组试题解析部分!


#include <stdio.h>
int main()
{
    char arr[] = { 'a','b','c','d','e','f' };
    printf("%d\n", sizeof(arr));    //6
    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;
}

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


0a2653c851af460fa595bd959398a8f1.png


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

下面进入讲解部分!


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


1.sizeof(arr)  : arr是数组名,并且单独放在sizeof内部,计算的是数组的总大小,单位为字节! 6


2.sizeof(arr + 0)  : arr是数组名,并非单独放在sizeof内部,arr表示首元素的地址!arr+0 还是首元素的地址!


2d65d23f6d4748949b924e4057485923.png


地址存储起来就需要4个字节,与char类型无关!(包过与其他类型也无关)


3.sizeof(*arr)  : arr 是首元素的地址!*arr 就是得到了首元素!sizeof(*arr) 计算的就是首元素的大小,(char类型)1个字节!


4.sizeof(arr[1])  : arr[0]是数组的第一个元素,则arr[1] 是数组的第二个元素, .sizeof(arr[1])计算的就是第二个元素(char类型)的大小!1个字节!


5.sizeof(&arr)  : &arr 取出的是数组的地址!sizeof(&arr)计算的是数组的地址!但是数组的地址也是地址,是地址就是4/8个字节!


6.sizeof(&arr + 1)  : &arr 的类型为: char (*)[6]  ;


6de278e6d6694ce5bb08e7e842b7e74b.png


&arr 是数组的地址!&arr+1跳过整个数组!!即指向 'f' 的后边!&arr的本质:还是地址,既然是地址,就是4/8个字节!


7.sizeof(&arr[0] + 1)  : &arr[0] 的类型为:char * 类型! &arr[0]  取出的是:'a'的地址! &arr[0] +1取出的是 :‘b' 的地址!是地址就是4/8个字节!


代码的运行结果为:


12c3b7f3f8814309a195c64f051d4445.png


到此为止,笔者所精心钻研指针和数组试题解析(2)部分已经结束!期待着后续部分!!


相关文章
|
1月前
|
算法 前端开发 数据处理
小白学python-深入解析一位字符判定算法
小白学python-深入解析一位字符判定算法
48 0
|
20天前
使用指针访问数组元素
【10月更文挑战第30天】使用指针访问数组元素。
30 3
|
19天前
使用指针访问数组元素
【10月更文挑战第31天】使用指针访问数组元素。
30 2
|
28天前
|
算法 索引
单链表题+数组题(快慢指针和左右指针)
单链表题+数组题(快慢指针和左右指针)
32 1
|
1月前
|
人工智能 前端开发 JavaScript
拿下奇怪的前端报错(一):报错信息是一个看不懂的数字数组Buffer(475) [Uint8Array],让AI大模型帮忙解析
本文介绍了前端开发中遇到的奇怪报错问题,特别是当错误信息不明确时的处理方法。作者分享了自己通过还原代码、试错等方式解决问题的经验,并以一个Vue3+TypeScript项目的构建失败为例,详细解析了如何从错误信息中定位问题,最终通过解读错误信息中的ASCII码找到了具体的错误文件。文章强调了基础知识的重要性,并鼓励读者遇到类似问题时不要慌张,耐心分析。
|
1月前
|
存储
如何使用指针数组来实现动态二维数组
指针数组可以用来实现动态二维数组。首先,定义一个指向指针的指针变量,并使用 `malloc` 为它分配内存,然后为每个子数组分配内存。通过这种方式,可以灵活地创建和管理不同大小的二维数组。
|
1月前
|
存储
如何通过指针数组来实现二维数组?
介绍了二维数组和指针数组的概念及其区别,详细讲解了如何使用指针数组模拟二维数组,包括定义与分配内存、访问和赋值元素、以及正确释放内存的步骤,适用于需要动态处理二维数据的场景。
|
1月前
|
存储 算法 C语言
C语言:什么是指针数组,它有什么用
指针数组是C语言中一种特殊的数据结构,每个元素都是一个指针。它用于存储多个内存地址,方便对多个变量或数组进行操作,常用于字符串处理、动态内存分配等场景。
|
1月前
魔法指针 之 二级指针 指针数组
魔法指针 之 二级指针 指针数组
19 1
|
1月前
|
存储
一篇文章了解区分指针数组,数组指针,函数指针,链表。
一篇文章了解区分指针数组,数组指针,函数指针,链表。
19 0
下一篇
无影云桌面