2024龙年特别篇 -- 魔法指针 之 指针变量的意义 指针运算

学习完指针变量:链接后,

我们继续学习指针变量的应用 

目录

程序展示

原始方式 

指针变量方式 

代码对比

指针运算

指针+-整数

用指针打印数组内容

使用指针打印1-10中的奇数 

指针-指针

指针的关系运算 


 


程序展示

打印一个有10个元素的数组,将其全置为1

原始方式 

int main()
{int arr[10] = { 0 };int sz = sizeof(arr) / sizeof(arr[0]);int i = 0;for (i = 0; i < sz; i++){//将数字全部置为1arr[i] = 1;//输出printf("%d ", arr[i]);}printf("\n");return 0;
}

指针变量方式 

让我们先看一段代码

int main()
{int a[10] = { 1,2,3,4,5,6,7,8,9,10 };//            0 1 2 3 4 5 6 7 8  9int sz = sizeof(a) / sizeof(a[0]);int* p = &a;//取a数组的地址printf("%d\n", a[1]);printf("%d\n", *(a + 1));printf("%d\n", *(p + 1));return 0;
}

结果会输出什么呢? 

 *(p+i) 或 * (a+i)是p+i 或a+i所指向的数组元素

([ ]是变址运算符,将a[i]按a+i计算地址,然后找出此地址单元的值)

小结:

可以看出,*(p+i),*(a+i),a[i]三者是等价的。

同理,我们也可以看出

*p 和 *arr 也是等价的,都是取首元素的地址

代码对比


指针运算

指针+-整数

用指针打印数组内容

int main()
{int a[10] = { 1,2,3,4,5,6,7,8,9,10 };int sz = sizeof(a) / sizeof(a[0]);int* p = &a;int i = 0;for (i = 0; i < sz; i++){/*方法①printf("%d ", *p);p++;*//*方法②*/printf("%d ", *(p + i));}printf("\n");return 0;
}

 结果打印输出

使用指针打印1-10中的奇数 

int main()
{int a[10] = { 1,2,3,4,5,6,7,8,9,10 };int* p = &a;int i = 0;for (i = 0; i < 5; i++){printf("%d ", *p);p += 2;}printf("\n");return 0;
}

结果打印输出 

 

倒序输出数组

int main()
{int a[10] = { 1,2,3,4,5,6,7,8,9,10 };//            0 1 2 3 4 5 6 7 8  9int sz = sizeof(a) / sizeof(a[0]);int* p = &a[9];//指向数组最后一个元素int i = 0;for (i = 0; i < sz; i++){printf("%d ", *(p - i));}printf("\n");return 0;
}

结果打印输出 

指针-指针

指针 - 指针 = 地址 - 地址

需要指向同一块空间

看下段代码👇

int main()
{int a[5] = { 1,2,3,4,5 };//          0 1 2 3 4int* p1 = &a[4];int* p2 = &a[0];int* p3 = &a[1];printf("%d\n", p1 - p2);printf("%d\n", p1 - p3);return 0;
}

结果打印输出 

 小结:指针相减,代表的是指针之间的距离(用数组的元素来进行度量)

再看下段代码👇

int my_strlen(char* s)
{char* p = s;while (*p != '\0')p++;return p - s;
}int main()
{printf("%d\n", my_strlen("abc"));return 0;
}

 结果打印输出为:3

解释一下这段代码:

这段代码是链表算长度和找尾节点

把字符串传过去的地址拷贝了一份叫p

p-s是:p向后走了多少就知道字符串首尾差了多少


指针的关系运算 

看下段代码

int main()
{int a[10] = { 1,2,3,4,5,6,7,8,9,10 };int sz = sizeof(a) / sizeof(a[0]);int* p = &a[0];while (p < a + sz){printf("%d ", *p);p++;}printf("\n");return 0;
}

代码结果输出 

代码解释


 

 ***********************************************************分割线*****************************************************************************
完结!!!
感谢浏览和阅读。
等等等等一下,分享最近喜欢的一句话:

“努力经营当下,直至未来明朗”。

我是白子寰,如果你喜欢我的作品,不妨你留个点赞+关注让我知道你曾来过。
你的点赞和关注是我持续写作的动力!!! 
好了划走把。

 

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

语言与科技创新(大语言模型对科技创新的影响)

1.科技创新中的语言因素 科技创新中的语言因素至关重要&#xff0c;具体体现在以下几个方面&#xff1a; 科技文献交流&#xff1a; 英语作为全球科学研究的通用语言&#xff0c;极大地推动了科技成果的国际传播与合作。科学家们在发表论文、报告研究成果时&#xff0c;大多选…

ChatGPT高效提问—prompt实践(教师助手)

ChatGPT高效提问—prompt实践&#xff08;教师助手&#xff09; 下面来看看ChatGPT在教育领域有什么用途。 首先设定ChatGPT的角色为高中教师助手。 输入prompt: ChatGPT输出&#xff1a; ​ 教师助手的角色已经设置完成。下面通过几种不同的情景演示如何使用。 1.1.1 制定…

Day34 贪心算法part03

K次取反后最大化的数组和 for num in nums:if k 0:breakif num < 0:num -numk - 1 这种直接遍历元素的赋值的话不改变数组里面的数&#xff01; 得写成下面这个样子 for i in range(len(nums)):if k 0:breakif nums[i] < 0:nums[i] -nums[i]k - 1 A.sort(keylambda …

2001-2022年368个地级市平均气温数据

2001-2022年368个地级市平均气温数据 1、时间:2001-2022年 2、范围&#xff1a;368个地级市 3、来源&#xff1a;基于NOAA下属NCEI提供的原始数据编制而成的。 4、指标&#xff1a;年份、省份、省份代码、城市、城市代码、平均气温 5、指标解释&#xff1a;平均气温指某一…

设计模式浅析

一、设计模式的使用场景 设计模式&#xff08;Design Patterns&#xff09;是在软件开发中经过验证的最佳实践&#xff0c;用于解决常见的设计问题。它们提供了一种可复用的解决方案&#xff0c;可以帮助开发人员提高代码质量、可维护性和可重用性。设计模式的采用通常在以下情…

【JavaEE】_JavaScript(Web API)

目录 1. DOM 1.1 DOM基本概念 1.2 DOM树 2. 选中页面元素 2.1 querySelector 2.2 querySelectorAll 3. 事件 3.1 基本概念 3.2 事件的三要素 3.3 示例 4.操作元素 4.1 获取/修改元素内容 4.2 获取/修改元素属性 4.3 获取/修改表单元素属性 4.3.1 value&#xf…

机器学习、深度学习、强化学习、迁移学习的关联与区别

Hi&#xff0c;大家好&#xff0c;我是半亩花海。本文主要了解并初步探究机器学习、深度学习、强化学习、迁移学习的关系与区别&#xff0c;通过清晰直观的关系图展现出四种“学习”之间的关系。虽然这四种“学习”方法在理论和应用上存在着一定的区别&#xff0c;但它们之间也…

Python学习之路-爬虫进阶:爬虫框架

Python学习之路-爬虫进阶:爬虫框架 了解框架 什么是框架 框架是为了为解决一类问题而开发的程序&#xff0c;框架两个字可以分开理解&#xff0c;框&#xff1a;表示指定解决问题的边界&#xff0c;明确要解决的问题&#xff1b;架&#xff1a;表达的是能够提供一定的支撑性…

FreeRTOS 队列管理

概览 基于 FreeRTOS 的应用程序由一组独立的任务构成——每个任务都是具有独立权 限的小程序。这些独立的任务之间很可能会通过相互通信以提供有用的系统功能。 FreeRTOS 中所有的通信与同步机制都是基于队列实现的。 本章期望让读者了解以下事情   如何创建一个队列   …

Starknet 的 JavaScript 库:Starknet.js、get-starknet和starknet-react

文章目录 Starknet 的 JavaScript 库Starknet.jsget-starknetstarknet-reactStarknet 的 JavaScript 库Starknet.js 官方:https://www.starknetjs.com/ Starknet.js 是一个与 Starknet 交互的 JavaScript 库,通常以脚本或去中心化形式进行交互应用程序。 Starknet.js 的灵感…

有限合伙协议书(模板)下

第六章 合伙事务的执行 第十七条 有限合伙人不执行合伙事务&#xff0c;对外不具有代表权。有限合伙企业由普通合伙人执行合伙事务。 第十八条 经全体合伙人一致同意可以委托一个普通合伙人&#xff08;也可以委托数个普通合伙人&#xff09;对外代表合伙企业&#xff0c;执…

【PyTorch】PyTorch中张量(Tensor)统计操作

PyTorch深度学习总结 第五章 PyTorch中张量(Tensor)统计操作 文章目录 PyTorch深度学习总结前言一、最值查找二、特殊值查询 前言 上文介绍了PyTorch中张量(Tensor)的计算操作&#xff0c;本文将介绍张量的统计操作。 一、最值查找 函数描述torch.max()找出张量中的最大值to…

Hive调优——count distinct去重优化

离线数仓开发过程中经常会对数据去重后聚合统计&#xff0c;而对于大数据量来说&#xff0c;count(distinct ) 操作消耗资源且查询性能很慢&#xff0c;以下是调优的方式。 解决方案一&#xff1a;group by 替代 原sql 如下&#xff1a; #7日、14日的app点击的用户数&#x…

C#面:<%# %>和<% %>有什么区别?

<%# %>和<% %>是ASP.NET中的两种不同的代码块标记。 <%# %> 是数据绑定表达式标记&#xff0c;用于在页面中绑定数据。它通常用于数据绑定控件&#xff08;如GridView、Repeater等&#xff09;&#xff0c;用于将数据源中的值绑定到控件的属性或者显示在页…

算法学习——LeetCode力扣回溯篇1

算法学习——LeetCode力扣回溯篇1 77. 组合 77. 组合 - 力扣&#xff08;LeetCode&#xff09; 描述 任何顺序 返回答案。 示例 示例 1&#xff1a; 输入&#xff1a;n 4, k 2 输出&#xff1a; [ [2,4], [3,4], [2,3], [1,2], [1,3], [1,4], ] 示例 2&#xff1a; 输…

[缓存] - 3.金融交易系统缓存架构设计

1. 交易数据特点 1.1 数据量极大 交易系统的数据量特大&#xff0c;主要来自以下几种类型的数据。 1.1.1 行情 行情是交易系统最为重要的数据&#xff0c;交易就是在不断变化的行情中寻找时机来实现盈利的。海量的行情主要分成两种&#xff0c;一种是tick数据&#xff08;也…

C#系列-C#EF框架实现事务处理(31)

在C#中使用Entity Framework (EF)框架实现事务处理主要涉及使用DbContext的Database.BeginTransaction方法来创建一个数据库事务&#xff0c;并确保在事务中的所有操作都成功执行后提交事务&#xff0c;或者在发生异常时回滚事务。 下面是一个使用EF Core进行事务处理的简单示…

年后面试,最好不要有这几种心态

大家好&#xff0c;我是老三&#xff0c;大家新年好&#xff0c;我在朋友圈看到有朋友已经在大张旗鼓地“内卷”&#xff0c;为年后的面试做准备。 成功的面试常常是源于实力运气&#xff0c;失败的面试可能会有各种各样的原因&#xff0c;知识点的盲区、和面试官不对眼、经验…

【机器学习案例4】为机器学习算法编码分类数据【含源码】

目录 编码分类数据 序数编码 标签编码 一次性编码 目标编码 目标编码的优点 目标编码的缺点 在现实生活中,收集的原始数据很少采用我们可以直接用于机器学习模型的格式,即数值型数据。因此,需要进行一些预处理,以便以正确的格式呈现数据、选择信息丰富的数据或降低其…

【C++函数探幽】内联函数inline

&#x1f4d9; 作者简介 &#xff1a;RO-BERRY &#x1f4d7; 学习方向&#xff1a;致力于C、C、数据结构、TCP/IP、数据库等等一系列知识 &#x1f4d2; 日后方向 : 偏向于CPP开发以及大数据方向&#xff0c;欢迎各位关注&#xff0c;谢谢各位的支持 目录 1. 前言2.概念3.特性…