sizeof运算和strlen函数的笔试题(三)

简介: sizeof运算和strlen函数的笔试题(三)
#include "stdio.h"
int main()
{
    int a[3][4] = {0};
    printf("%d\n",sizeof(a));
    printf("%d\n",sizeof(a[0][0]));
    printf("%d\n",sizeof(a[0]));
    printf("%d\n",sizeof(a[0]+1));
    printf("%d\n",sizeof(*(a[0]+1)));
    printf("%d\n",sizeof(a+1));
    printf("%d\n",sizeof(*(a+1)));
    printf("%d\n",sizeof(&a[0]+1));
    printf("%d\n",sizeof(*(&a[0]+1)));
    printf("%d\n",sizeof(*a));
    printf("%d\n",sizeof(a[3]));
    return 0;
}

1. sizeof( a )

sizeof➕数组名,测的是整个数组的大小,所以结果是

3(行)*4(列)*4(1个元素的字节数)=48个字节

2. sizeof( a [ 0 ][ 0 ] )

a[0][0]代表这个二维数组的首元素,是int类型,结果是4字节。


3. sizeof( a[ 0 ] )

既然a[0]相当于第一行数组名,那sizeof( a[ 0 ] )就是计算第一行的大小,结果为4*4=16字节。

4. sizeof( a[ 0 ] + 1 )

上面说a[0]是第一行数组名,但是在这并不是单独出现的,那这个数组名代表的就是第一行首元素地址,加一就是第一行第二个元素地址,既然是地址,就是4/8字节。

5. sizeof( *a[ 0 ] + 1 )

计算的是第一行第二个元素的大小,也就是a[0][1],数据类型是int,结果是4字节。

6. sizeof( a + 1 )

若不是单独出现的a,代表的就是第一行的地址,相当于a[0],其数据类型就是int (*)[4],a➕1会跳过一行的地址来到第二行,既然是地址就是4/8字节。

7. sizeof( *(a + 1))

a+1是第二行地址,解引用后是访问第二行数组所有元素,结果是4*4=16字节。

8. sizeof( &a[ 0 ] + 1

&a[0]取得是第一行的地址,+1后取的是第二行地址,数据类型是int(*)[4] ,结果是4/8字节。

9. sizeof( *(&a[ 0 ] + 1) )

&a[0] + 1是第二行地址,解引用后是访问第二行整个数组,结果是4*4=16字节。

10. sizeof( *a )

并不是单独的a,所以是第一行地址,解引用后访问第一行所有元素,结果是4*4=16字节。

11. sizeof( a[ 3 ] )

a[3]是数组名,计算整个一行数组大小,结果4*4=16字节。

相关文章
|
关系型数据库 MySQL Windows
mysql彻底卸载干净的5个步骤,超多图超详细保姆级教程最新教程新手小白轻松上手
mysql彻底卸载干净的5个步骤,超多图超详细保姆级教程最新教程新手小白轻松上手
24010 2
|
设计模式 C++
C++设计模式:面试题精选集
C++设计模式:面试题精选集
458 0
|
存储 安全 数据库连接
【C++智能指针】深入探究C++智能指针:自定义删除器的设计与选择
【C++智能指针】深入探究C++智能指针:自定义删除器的设计与选择
749 0
|
Serverless
【PTA刷题+代码+详解】求二叉树度为1的结点个数(递归法)
【PTA刷题+代码+详解】求二叉树度为1的结点个数(递归法)
900 0
|
人工智能 Ubuntu Shell
【Ubuntu工具】安装教程:Ubuntu系统上源码编译安装QT5.15.13(有坑)
【Ubuntu工具】安装教程:Ubuntu系统上源码编译安装QT5.15.13(有坑)
1840 0
|
Shell BI 开发工具
【问题解决】Git报错:failed to push some refs to xxxxx
Git报错:failed to push some refs to xxxxx
1444 0
|
3天前
|
Android开发 开发者 Windows
这是我设计的一种不关机,然后改造操作系统的软件设计思路2.0版本
本文介绍了在不重启系统的情况下实现操作系统改造的两种方案。第一种方案通过SLFM Recovery模式,在独立于操作系统的最高权限环境下完成系统更新与改造,并支持断电恢复与失败回滚。第二种方案采用多分区机制,通过SLFM套件在独立分区中完成系统改造,适用于可中断与不可中断服务场景,确保系统更新过程的安全与稳定。
219 132