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字节;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/404586.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

R语言【base】——abs(),sqrt():杂项数学函数

Package base version 4.2.0 Description abs(x) 计算 x 的绝对值,sqrt(x) 计算 x 的正平方根。 Usage abs(x) sqrt(x) Arguments 参数【x】:一个数值或复数向量或数组。 Details 这些都是内部泛型原语函数:可以为它们单独定义方法,也可以…

Elasticsearch从入门到精通-01认识Elasticsearch

Elasticsearch从入门到精通-01认识Elasticsearch 👏作者简介:大家好,我是程序员行走的鱼 🍂博主从本篇正式开始ES学习,希望小伙伴可以一起探讨 📖 本篇主要介绍和大家一块简单认识下ES并了解ES中的主要角色…

鸿蒙自定义侧滑菜单布局(DrawerLayout)

前言 为了实现安卓中的侧滑菜单布局效果,通过查找鸿蒙的布局控件,发现SideBarContainer控件有点像,但是使用中发现并不是很符合我们的UI交互效果,因此我在鸿蒙中通过自定义布局的方式实现,本文主要介绍该自定义控件如…

第3.6章:StarRocks数据导入——DataX StarRocksWriter

一、Datax 1.1 DataX 3.0概述 DataX3.0是一个异构数据源离线同步工具,可以方便的对各种异构数据源进行高效的数据同步。 其github地址为: https://github.com/alibaba/DataX/blob/master/introduction.mdhttps://github.com/alibaba/DataX/blob/mast…

【Java代码审计】XSS漏洞

1. XSS漏洞 XSS(Cross Site Scripting,为了和层叠样式表(Cascading Style Sheet,CSS)有所区分,故称XSS)跨站脚本攻击是一种针对网站应用程序的安全漏洞攻击技术。它可以实现用户会话劫持、钓鱼攻击、恶意重…

罗克韦尔AB的PLC实现ModbusTCP和ModbusRTU协议标签方式通讯

本文是通过IGT-DSER智能网关读写AB罗克韦尔Compact、Control系列PLC的标签数据缓存并转为Modbus从站协议,与上位机通讯的案例。 打开智能网关的参数软件(下载地址),通过功能->数据转发与平台对接,再选择数据转发与缓存’,进入以…

浏览器录屏技术:探索网页内容的视觉记录之道

title: 浏览器录屏技术:探索网页内容的视觉记录之道 date: 2024/2/23 14:32:49 updated: 2024/2/23 14:32:49 tags: 浏览器录屏技术原理Web API应用场景用户体验在线教育产品演示 在当今数字化时代,浏览器录屏技术已经成为了一种强大的工具,…

基于springboot+vue的视频网站系统(前后端分离)

博主主页:猫头鹰源码 博主简介:Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战,欢迎高校老师\讲师\同行交流合作 ​主要内容:毕业设计(Javaweb项目|小程序|Pyt…

力扣随笔之按奇偶排序数组(简单905)

思路1:根据双指针对撞指针的思路,定义一个左指针从数组前端开始遍历,定义一个右指针从后端开始遍历,这时候有四种情况 左奇右偶:这种情况需要将其位置交换,将偶数提前,奇数后移左奇右奇&#xf…

【Lazy ORM】 小工具 acw 本地客户端 你负责点击页面,他负责输出代码

介绍 wu-smart-acw-client 简称acw-client&#xff0c;是一个基于Lazy ORM定制的客户端代码生成小工具 Lazy ORM 小工具 acw 本地客户端 你负责点击页面&#xff0c;他负责输出代码安装 <dependency><groupId>top.wu2020</groupId><artifactId>wu-sma…

Qt_快速安装指南

下载Qt在线安装程序&#xff08;不仔细介绍&#xff09;注册Qt账号&#xff08;不仔细介绍&#xff09;使用快速运行的命令&#xff0c;按照指定的下载地址下载 在Qt指定目录打开cmd命令窗口.\eqt-unified-windows-x86-4.0.1-1-online. exe --mirror https://mirrors.ustc.edu.…

计算机设计大赛 深度学习卷积神经网络垃圾分类系统 - 深度学习 神经网络 图像识别 垃圾分类 算法 小程序

文章目录 0 简介1 背景意义2 数据集3 数据探索4 数据增广(数据集补充)5 垃圾图像分类5.1 迁移学习5.1.1 什么是迁移学习&#xff1f;5.1.2 为什么要迁移学习&#xff1f; 5.2 模型选择5.3 训练环境5.3.1 硬件配置5.3.2 软件配置 5.4 训练过程5.5 模型分类效果(PC端) 6 构建垃圾…

Cesium 展示——加载 tileset.json 格式的模型数据

文章目录 需求分析需求 已给 tileset.json 文件,现需加载该模型文件, 该模型特点:模型上的各模块均可以进行点击设置,且相机视角拉近后可以看到内部隐藏的物件模块 分析 tileset.json :模型数据【模型加载】方法export function init3dTileLayer (option) {var tilesetMo…

【SpringBoot3】Spring Security 常用配置总结

注&#xff1a;本文基于Spring Boot 3.2.1 以及 Spring Security 6.2.1 相关文章 【SpringBoot3】Spring Security 核心概念 【SpringBoot3】Spring Security 常用注解 【SpringBoot3】Spring Security 详细使用实例&#xff08;简单使用、JWT模式&#xff09; 【SpringBoot3】…

ChatGPT调教指南 | 咒语指南 | Prompts提示词教程(二)

在我们开始探索人工智能的世界时&#xff0c;了解如何与之有效沉浸交流是至关重要的。想象一下&#xff0c;你手中有一把钥匙&#xff0c;可以解锁与OpenAI的GPT模型沟通的无限可能。这把钥匙就是——正确的提示词&#xff08;prompts&#xff09;。无论你是AI领域的新手&#…

flinksql 流表转换, 自定义udf/udtf,SQL 内置函数及自定义函数

flinksql 流表转换&#xff0c; 自定义udf/udtf 1、标量函数2、表函数3、聚合函数4、表聚合函数 1、在大多数情况下&#xff0c;用户定义的函数必须先注册&#xff0c;然后才能在查询中使用。不需要专门为 Scala 的 Table API 注册函数。 2、函数通过调用 registerFunction&am…

yolov9目标检测报错AttributeError: ‘list‘ object has no attribute ‘device‘

最近微智启软件工作室在运行yolov9目标检测的detect.py测试代码时&#xff0c;报错&#xff1a; File “G:\down\yolov9-main\yolov9-main\detect.py”, line 102, in run pred non_max_suppression(pred, conf_thres, iou_thres, classes, agnostic_nms, max_detmax_det) Fil…

Python urllib、requests、HTMLParser

HTTP协议 HTTP 协议&#xff1a;一般指HTTP(超文本传输)协议。 HTTP是为Web浏览器和Web服务器之间的通信而设计的&#xff0c;基于TCP/IP通信协议嘞传递数据。 HTTP消息结构 客户端请求消息 客户端发送一个HTTP请求到服务器的请求消息包括以下格式 请求行(request line)请求…

排序算法之——归并排序

归并排序 1. 基本思想2. 数据的分解3. 数据的合并4.归并排序的实现4.1 递归实现4.1.1 一个易错点4.1.2 运行结果 4.2 非递归实现4.2.1 图示思路4.2.2 代码实现4.2.3 一个易错点4.2.4 修改后的代码4.2.5 运行结果 6. 时间复杂度7. 空间复杂度8. 稳定性9. 动图演示 1. 基本思想 …

h-table(表格列表组件的全封装)

文章目录 概要h-table的封装过程查询组件封装 h-highForm结果页右侧工具栏封装RightToolbar结果页列表组件h-table结果页vue页面使用js文件有需要的请私信博主&#xff0c;还请麻烦给个关注&#xff0c;博主不定期更新组件封装&#xff0c;或许能够有所帮助&#xff01;&#x…