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

C语言 | sizeof与strlen的区别(附笔试题)

目录:

1. sizeof和strlen的对比

2. 数组和指针 笔试题解析

3. 指针运算 笔试题解析 

内容多多,需耐心看完,加油!!!


 一.sizeof和strlen的对比

1.1 sizeof

在学习操作符的时候,我们学习了 sizeof , sizeof为单目操作符。

用来计算变量所占内存空间⼤小的,单位是字节。如果操作数是类型的话,计算的是使用类型创建的变量所占内存空间的大小。 sizeof 只关注占⽤内存空间的大小,不在乎内存中存放什么数据。

例如: 

d9c8f12e05fd4731a06c95e3343ae736.png

1.2 strlen 

strlen 是C语言 库函数,功能是求字符串⻓度。函数原型如下:

size_t strlen ( const char * str );

统计的是从 strlen 函数的参数 str 中这个地址开始向后, \0 之前字符串中字符的个数。 strlen 函数会⼀直向后找 \0 字符,直到找到为⽌,所以可能存在越界查找。

2bc731fbf4594163be9de41e03098ea0.png

1.3 sizeof 和 strlen的对比

4fff3f15a78941de8635e47f86cb6250.png


 二. 数组和指针笔试题解析

2.1 ⼀维数组

自己可以先计算下面10个问题的答案,之后会给出解析。

int a[] = {1,2,3,4}; //4个元素printf("%zd\n",sizeof(a)); //1
printf("%zd\n",sizeof(a+0)); //2
printf("%zd\n",sizeof(*a)); //3
printf("%zd\n",sizeof(a+1)); //4
printf("%zd\n",sizeof(a[1])); //5
printf("%zd\n",sizeof(&a)); //6
printf("%zd\n",sizeof(*&a)); //7
printf("%zd\n",sizeof(&a+1)); //8
printf("%zd\n",sizeof(&a[0])); //9
printf("%zd\n",sizeof(&a[0]+1)); //10

 【之前的文章也讲到,关于对数组名的理解:

数组名是数组首元素(第一个元素)的地址

but有两个例外:

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

2. &数组名--数组名表示整个数组,取出的是整个数组的地址】

第1--5题:(x64环境下)

015c6881a88546a0a92d2f656624f147.png

第6--10题:

a3fca4bbe78d49d383d101b898b58485.png

 2.2 字符数组

代码1:主要考查sizeof

char arr[] = {'a','b','c','d','e','f'};//存放6个字符
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));

解析为:

e6e8256249634e9abf6f6f97c2f95743.png

 代码2:主要考查strlen

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));

解析为:

725aa55de2ee40be886de251dcc84b98.png

代码3:主要考查sizeof

char arr[] = "abcdef";
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));

解析为: 

517ae3b4951d4f96b788ed9102bbdcd3.png

代码4:主要考查strlen

char arr[] = "abcdef";
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));

解析为: 

52f62c07e7fa4b8f9edd38147bb009d7.png

代码5:

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

 解析为:

21372c9c91714b06a19d482a79e772d3.png

代码6:

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

解析为:

7b4479a3c25d4e2c9b2290469712547a.png

2.3 ⼆维数组

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]));

 解析为:

ba5ebbe819164bf6bd76720f398e0988.png

3. 指针运算笔试题解析

 题目1: 

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

程序的结果是什么?

f80b2fb64be945ccb3c1692e9c368fe0.png

5f72eacbb08342ef8bb695395116752a.png

题目2 :

在X86(32位)环境下  假设结构体的大小是20个字节  程序输出的结果是啥?

struct Test
{int Num;char *pcName;short sDate;char cha[2];short sBa[4];
}*p = (struct Test*)0x100000;
int main()
{printf("%p\n", p + 0x1);printf("%p\n", (unsigned long)p + 0x1);printf("%p\n", (unsigned int*)p + 0x1);return 0;
}

解析为:

5522b32581244157b7d653fc1f825f32.png

题目3:

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

 解析为:

dd9c94fb419549209a75b3fc922f8528.png

fbee3dcadaca4964850dbf27ace29d24.png

题目4:

假设环境是x86环境,程序输出的结果是啥?

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

解析为:

857516129a3243daa2be77ab9eba6e11.png

 

 

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

相关文章:

  • AI自动绘画器介绍和应用场景
  • java二叉树前中后序遍历
  • 【LeetCode刷题笔记】LeetCode 1365.有多少小于当前数字的数字
  • 室内定位中文综述阅读
  • 微信小程序uniapp+vue电力巡线任务故障报修管理系统2q91t
  • springboot国际化多语言
  • set和map
  • Open CASCADE学习|求曲面的参数空间
  • 代码随想录阅读笔记-二叉树【总结】
  • 【SpringBoot整合系列】SpringBoot整合FastDFS(二)
  • L2-2 巴音布鲁克永远的土(二分+并查集)
  • Spring Cloud学习笔记:Eureka简介,Eureka简单样例
  • 【漏洞复现】WordPress Welcart 任意文件读取漏洞(CVE-2022-4140)
  • 快速排序:深入解析其原理、实现与性能特性
  • 一文看懂Mac地址
  • 2024.4.10作业
  • python - Django创建项目
  • WPF —— 动画缩放变换
  • SQL注入---盲注
  • PlanUML和Mermaid哪个好?
  • leetcode 343. 整数拆分
  • 【MATLAB源码-第180期】基于matlab的PTS,SLM,CPFilter三种降低OFDM系统的PAPR仿真。
  • 学透Spring Boot — 004. Spring Boot Starter机制和自动配置机制
  • 面试算法-170-二叉树的最大深度
  • 【数据结构】哈希
  • Kubernetes(k8s)监控与报警(qq邮箱+钉钉):Prometheus + Grafana + Alertmanager(超详细)
  • STM32-04基于HAL库(CubeMX+MDK+Proteus)中断案例(按键中断扫描)
  • 第十五篇:Mybatis
  • 【MacBook系统homebrew镜像记录】
  • 深拷贝总结