当前位置: 首页 > news >正文

笔试题详解(C语言进阶)

前言

        欢迎阅读本篇文章!本篇文章通过一个笔试题来加强我们对C语言的理解,希望对你有帮助。后续我会写一个栏目,集合我见到的C语言题目,进行分析讲解。

1、题目一

        判断下面程序的输出结果:(下面说的地址4/8字节是因为对于不同的编译环境地址的大小不同,32位环境为4字节,64位环境为8字节)

#include <stdio.h>
int main()
{int a[] = { 1,2,3,4 };printf("%d\n", sizeof(a));              printf("%d\n", sizeof(a + 0));			printf("%d\n", sizeof(*a));				printf("%d\n", sizeof(a + 1));			printf("%d\n", sizeof(a[1]));		printf("%d\n", sizeof(&a));				printf("%d\n", sizeof(*&a));			printf("%d\n", sizeof(&a + 1));			 printf("%d\n", sizeof(&a[0]));			printf("%d\n", sizeof(&a[0] + 1));		return 0;
}

        我们可以尝试去写出这些代码的输出结果,然后我将放出答案,参照答案看是否有不同。 

1.2结果

        这个结果是否符合你的预期呢?

1.3 分析

        我们对语句进行逐一分析:

    printf("%d\n", sizeof(a));              //16

  sizeof(数组名),数组名表示整个数组,计算的是整个数组的大小,单位是字节   

 printf("%d\n", sizeof(a + 0));            //4

 a不是单独放在sizeof内部,也没有取地址,所以a就是首元素的地址,a+0还是首元素的地址,只要是地址,大小就是4/8个字节

 printf("%d\n", sizeof(*a));                //4

   这里的a表示的是首元素的地址,*a表示首元素,首元素为整形,大小为4字节

 printf("%d\n", sizeof(a + 1));            //4

   a是首元素的地址,a+1是第二个元素的地址,大小为地址的大小,为4/8字节

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

 a[1]为数组第二个元素,为整型,大小为4四字节

    printf("%d\n", sizeof(&a));                //4

 &a取出的是数组的地址,地址大小就是4/8字节

 printf("%d\n", sizeof(*&a));            //16

这个重点讲一下:a和&先结合,成为一个指向整个数组的指针,然后*访问它,访问出来一整个数组,因此大小为整个数组的大小,为16                
    

printf("%d\n", sizeof(&a + 1));            //4

 &a+1还是一个地址,地址大小还是4/8,只不过这里加1直接跳过整个数组指向了数组后面一个地址。

printf("%d\n", sizeof(&a[0]));            //4

a[0]是数组首元素,&a[0]取出首元素的地址,所以大小为int类型大小,4字节

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

&a[0]是首元素地址,&a[0]+1是第二个元素的地址,大小为int类型大小,4字节

2、题目二

#include <stdio.h>
int main()
{char arr[] = { 'a','b','c','d','e','f' };printf("%d\n", sizeof(arr));printf("%d\n", sizeof(arr + 0));printf("%d\n", sizeof(*arr));printf("%d\n", sizeof(arr[1]));printf("%d\n", sizeof(&arr));printf("%d\n", sizeof(&arr + 1));printf("%d\n", sizeof(&arr[0] + 1));return 0;
}

        同样地,先自己算算吧,有了上面的案例,我相信你做这道题的正确率会提高很多。

2.1 结果 

        下面进行分析

2.2 分析

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

数组名单独放在sizeof内部,表示整个数组的大小,为6

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

arr + 0 是数组首元素的地址,大小为4/8字节

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

 *arr就是首元素,大小是char类型的大小,为1

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

arr[1]同样为数组的首元素,大小为char类型的大小,1字节

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

 &arr是数组地址,是地址就是4/8字节

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

&arr + 1,指向整个数组后面一个位置的地址,也还是地址,是地址,大小就是4/8字节

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

 &a[0]是数组第一个元素的地址,+1指向第二个元素,还是地址,大小为4/8字节

3、结语

        这样两道题目就分析完了,希望对你有所帮助。

http://www.lryc.cn/news/303527.html

相关文章:

  • ClickHouse快速上手
  • 蓝桥杯DP算法——背包问题(C++)
  • 【LeetCode+JavaGuide打卡】Day22|235. 二叉搜索树的最近公共祖先、701.二叉搜索树中的插入操作、450.删除二叉搜索树中的节点
  • Stable Diffusion WebUI 界面介绍
  • Cocos2dx-lua ScrollView[一]基础篇
  • QT应用软件【协议篇】周立功CAN接口卡代码示例
  • JVM对象的创建流程与内存分配
  • docker (六)-进阶篇-数据持久化最佳实践MySQL部署
  • 力扣题目训练(17)
  • 【react】react中和vue中的provide/inject、context写法示例
  • MySQL 的存储引擎(基本介绍)
  • Unity3D 实现基于物理引擎的绳子关节解析详解
  • C语言二级易忘易错易混知识点(自用)
  • js_三种方法实现深拷贝
  • 【图论经典题目讲解】CF715B - Complete The Graph
  • [office] excel中数据汇总的大全教程文字版 #知识分享#经验分享#知识分享
  • leetcode经典题库(简单)
  • python coding with ChatGPT 打卡第21天| 二叉树:最近公共祖先
  • openGauss学习笔记-224 openGauss性能调优-系统调优-数据库系统参数调优-数据库并发队列参数调优
  • UE5 C++ 创建可缩放的相机
  • Fabric中的溯源方法
  • 混子文章|蓝桥杯一题 -平方差
  • 计算机视觉基础:【矩阵】矩阵选取子集
  • 解决laravel-admin安装报错1071 Specified key was too long问题
  • 【Python---六大数据结构】
  • 一个简短的补充------对链表练习题的补充补充
  • Spring最新核心高频面试题(持续更新)
  • [计网底层小探索]:实现并部署多线程并发Tcp服务器框架(基于生产者消费者模型的线程池结构)
  • Spring Boot 笔记 020 redis集成
  • 防火墙——计算机网络