指针加1的含义、指针减法运算

2023-05-16

指针加1的含义

  • 一、p+1
    • 实例
    • 运行结果
  • 二、*(p+1) 与 *p+1
    • 实例
    • 运行结果
  • 三、*p++
    • 实例
    • 运行结果
  • 四、指针减法运算
    • 实例
    • 运行结果
  • 五、void*
  • 六、指针用来做什么?

一、p+1

p+1 表示地址值加上指针所指类型的 sizeof(),也就是指向了下一个元素

实例

#include <stdio.h>
int main()
{
	char a[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
	char* p1 = a;
	printf("p1=%p\n", p1);
	printf("p1+1=%p\n", p1 + 1);

	int b[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
	int* p2 = b;
	printf("p2=%p\n", p2);
	printf("p2+1=%p\n", p2 + 1);

	float c[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
	float* p3 = c;
	printf("p3=%p\n", p3);
	printf("p3+1=%p\n", p3 + 1);

	double d[] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
	double* p4 = d;
	printf("p4=%p\n", p4);
	printf("p4+1=%p\n", p4 + 1);

	return 0;
}

运行结果

在这里插入图片描述

二、*(p+1) 与 *p+1

实例

#include <stdio.h>
int main()
{
	char a[] = { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18 };
	char* p1 = a;
	printf("*p1=%d\n", *p1);
	printf("*(p1+1)=%d\n", *(p1 + 1));
	printf("*p1+1=%d\n", *p1 + 1);

	int b[] = { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18 };
	int* p2 = b;
	printf("*p2=%d\n", *p2);
	printf("*(p2+1)=%d\n", *(p2 + 1));
	printf("*p2+1=%d\n", *p2 + 1);

	float c[] = { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18 };
	float* p3 = c;
	printf("*p3=%f\n", *p3);
	printf("*(p3+1)=%f\n", *(p3 + 1));
	printf("*p3+1=%f\n", *p3 + 1);

	double d[] = { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18 };
	double* p4 = d;
	printf("*p4=%lf\n", *p4);
	printf("*(p4+1)=%lf\n", *(p4 + 1));
	printf("*p4+1=%lf\n", *p4 + 1);

	return 0;
}

运行结果

在这里插入图片描述

三、*p++

含义:取出 p 所指的那个数据,之后把 p 移到下一个位置去,另外 * 的优先级没有 ++ 高。

实例

#include <stdio.h>
int main()
{
	char a[] = { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18, -1 };
	char* p = a;
	for (int i = 0; i < sizeof(a) / sizeof(a[0]) - 1; i++) {
		printf("%d\t", p[i]);
	}
	printf("\n");
	while (*p != -1) {
		printf("%d\t", *p++);
	}
	printf("\n");
	for (p = a; *p != -1; p++) {
		printf("%d\t", *p);
	}
	printf("\n");
	for (p = a; *p != -1;) {
		printf("%d\t", *p++);
	}
	printf("\n");

	return 0;
}

运行结果

在这里插入图片描述

四、指针减法运算

实例

#include <stdio.h>
int main()
{
	char a[] = { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18 };
	char* p1 = a;
	char* p2 = &a[5];
	printf("p1=%p\n", p1);
	printf("p2=%p\n", p2);
	printf("p2-p1=%d\n", p2 - p1);
	printf("*p1=%d\n", *p1);
	printf("*p2=%d\n", *p2);
	printf("*p2-*p1=%d\n", *p2 - *p1);

	int b[] = { 0, 2, 4, 6, 8, 10, 12, 14, 16, 18 };
	int* p3 = b;
	int* p4 = &b[5];
	printf("p3=%p\n", p3);
	printf("p4=%p\n", p4);
	printf("p4-p3=%d\n", p4 - p3);
	printf("*p3=%d\n", *p3);
	printf("*p4=%d\n", *p4);
	printf("*p4-*p3=%d\n", *p4 - *p3);

	return 0;
}

运行结果

在这里插入图片描述

从结果可以分析出:
相减所得到的差并不是两个地址的差,而是这两个地址的差除以 sizeof()的数据类型,也就是在两个地址中间有几个这种数据类型的东西。char 类型地址差是 5,所以相减的结果是 5(char 类型占1个字节);int 类型地址差是 20,所以相减的结果是 5(int 类型占4个字节)

五、void*

int* p = &i;
void* q = (void*)p;

i 是 int 类型,p 和 q 都指向 i,通过 p 看 i 时,认为 i 是 int 类型;通过 q 看 i 时,认为 i 是 void 类型。

六、指针用来做什么?

  • 需要传入较大的数据时用作参数
  • 传入数组后对数组做操作
  • 函数返回不止一个结果
  • 需要用函数来修改不止一个变量
  • 动态申请的内存
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

指针加1的含义、指针减法运算 的相关文章

  • 基于GPT-2实现图像文本生成

    原理 使用GPT 2模型处理文本 xff0c 做decoder 使用google的vit base patch16 224模型处理图像 xff0c 做encoder 最后通过VisionEncoderDecoderModel将这两个模型粘起
  • C语言中常见的两个比较字符串是否相等的函数strcmp和strncmp

    函数 xff1a strcmp和strncmp strcmp 使用格式 xff1a include lt string h gt int strcmp const char s1 const char s2 设这两个字符串为str1 xff
  • sprintf和printf 用法的区别

    printf 的作用是标准化输出 xff0c 默认的对象是标准输出缓冲区 xff0c 要有一定的条件才能把缓冲区里面的数据输出 sprintf 作用是格式化输出函数 xff0c 保存字符串到缓冲区中 xff0c 起到拼接字符串的作用 功能
  • 第六篇,STM32脉冲宽度调制(PWM)编程

    1 PWM概念 PWM叫脉冲宽度调制 Pulse Width Modulation xff0c 通过编程控制输出方波的频率和占空比 高低电平的比例 xff0c 广泛应用在测量 xff0c 通信 xff0c 功率控制等领域 呼吸灯 xff0c
  • 第十篇,STM32串口蓝牙编程

    1 串口蓝牙概念 串口蓝牙是一个蓝牙模块 xff0c 内部有蓝牙模块和程序 xff0c 可以进行蓝牙通信 xff0c 同时提供一个串口接口 xff0c 通过串口可以配置蓝牙模块进行数据传输 2 使用串口3连接蓝牙模块 3 手机上安装蓝牙调试
  • LeetCode岛屿问题通用解决模板

    文章目录 前言第一题 xff1a 求岛屿的周长模板整理遍历方向确定边界重复遍历问题处理 模板解第一题第二题 xff1a 求岛屿数量第三题 xff1a 岛屿的最大面积第四题 xff1a 统计子岛屿第五题 xff1a 统计封闭岛屿的数目第六题
  • 第十四篇,STM32的CAN总线通信

    1 CAN总线的概念 CAN指的是控制器局域网网络 Controller Area Network xff0c 由德国博世汽车电子厂商开发出来 CAN使用差分信号 xff0c 具有较强的抗干扰能力和传输稳定性 CAN属于多主通信 xff0c
  • OpenCV图像处理学习十九,像素重映射cv::remap

    一 像素重映射概念 重映射就是把输入图像中各个像素按照制定的规则顺序映射到另外一张图像的对应位置上去 xff0c 形成一张新的图像 二 像素映射API函数接口 cv remap xff08 InputArray src 输入图像 Outpu
  • OpenCV图像处理学习二十一,直方图比较方法

    一 直方图比较 直方图比较是对输入的两张图像进行计算得到直方图H1与H2 xff0c 归一化到相同的尺度空间 xff0c 然后可以通过计算H1与H2的之间的距离得到两个直方图的相似程度 xff08 每张图像都有唯一的直方图与之对应 xff0
  • 嵌入式FreeRTOS学习九,任务链表的构成,TICK时间中断和任务状态切换调度

    一 tskTaskControlBlock 函数结构体 在tskTaskControlBlock 任务控制块结构体中 xff0c 其中有任务状态链表和事件链表两个链表成员 xff0c 首先介绍任务状态链表这个结构 xff0c 这个链表通常用
  • SOAP传输协议

    一 HTTP传输协议 超文本传输协议 xff08 HyperText Transfer Protocol xff0c 缩写 xff1a HTTP xff09 xff0c 它是基于请求 响应的模式协议 xff0c 客户端发出请求 xff0c
  • ONVIF简介

    一 什么是ONVIF ONVIF规范描述了网络视频的模型 接口 数据类型以及数据交互的模式 并复用了一些现有的标准 xff0c 如WS系列标准等 ONVIF规范的目标是实现一个网络视频框架协议 xff0c 使不同厂商所生产的网络视频产品 x
  • gsoap工具生成onvif设备搜索(remotediscovery)代码框架

    什么是gsoap工具 xff1f gSOAP 提供了两个工具来方便开发人员使用 C C 43 43 语言快速开发Web 服务应用 xff0c 通过 gSOAP 提供的这两个工具 xff0c 开发人员可以快速生成服务端与客户端代码框架 xff
  • Latex之给字符上加横线、波浪等

    Latex 前几天想在 x x x 上加波浪号 xff0c 一时间忘记怎么打 xff0c 现在记录下来 xff0c 以后好查阅 加 号 xff1a hat x 加横线 xff1a overline x 加宽 xff1a widehat x
  • 数据结构笔记-2(线性表)

    线性表 2 1 线性表 1 定义 是零个或多个具有相同类型的数据元素的有序数列 xff1b xff08 长度等于零的线性表为空表 xff09 非空线性表通常记为 xff1a L xff1d a 1 xff0c a 2 xff0c xff0c
  • 数据结构-6(图)

    图 图的逻辑结构 图的定义 xff1a 图是由顶点的有穷非空集合和顶点之间边的集合组成 xff0c 通常表示为 xff1a G 61 V xff0c E 其中 xff1a G表示一个图 xff0c V是图G中顶点的集合 xff0c E是图G
  • 【leetcode常见面试题】螺旋矩阵解题思路

    文章目录 螺旋矩阵解题思路先找行进路线找每条路线的结束位置再找每条路线的结束位置模拟行走 螺旋矩阵 II总结 螺旋矩阵 解题思路 本题可以采用模拟的方式 xff0c 设4种行走方向 xff0c 如下图 xff1a 先找行进路线 4个方向的行
  • C++面向对象程序设计学习心得

    C 43 43 面向对象程序设计学习心得 经过几周c 43 43 面向对象程序设计的学习 xff0c 对面向对象程序设计有了一些了解 递归 简单地讲 xff0c 递归就是程序直接或间接调用本身的编程技巧 xff0c 通过把一个不能或不好解决
  • STL学习心得

    STL概述 STL组件 1 容器 xff08 Container xff09 xff0d 管理某类对象的集合 2 迭代器 xff08 Iterator xff09 xff0d 在对象集合上进行遍历 xff08 注意 xff1a 这些集合可能

随机推荐