博客
关于我
C语言指针运算
阅读量:775 次
发布时间:2019-03-24

本文共 1123 字,大约阅读时间需要 3 分钟。

指针基础与操作指南

1. p + 1 的含义

p + 1 的含义并非简单地将一个整数加 1,而是对指针执行操作。这里的 +1 是对指针本身的操作,类似于在内存中移动固定大小的空间。通过不断对指针执行 +1 操作,可以逐个访问数组中的元素。

array 示例

例如,考虑以下代码:

int a[] = {1, 2, 3, 4, 5};int *p = a;
  • p 指向数组 a 的第一个元素。
  • p + 1 式式操作将 p 移动到数组下一个元素的位置。

运行以下程序可以更直观地观察:

#include 
int main() { int a[] = {1, 2, 3, 4, 5}; int *p = a; printf("p = %p\n", p); printf("p+1 = %p\n", p+1); printf("*p = %d\n", *p); // *p 即 a[0] printf("*(p+1) = %d", *(p+1)); // *(p+1) 即 a[1] return 0;}

输出结果如下:

p = 000000000062FE00p+1 = 000000000062FE04*p = 1*(p+1) = 2

指针的其他操作

指针的算术运算

  • p + np -= n 类似于 p += n 的操作,分别用于在内存中向前或向后移动 n 个单位。
  • p++--p 实则是 p = p + 1p = p - 1 的意思。

两指针的比较

int a[] = {1, 2, 3, 4, 5};int *p  = &a[0];int *p1 = &a[4];
  • p 指向 a[0]p1 指向 a[4]
  • p1 - p = 4,这等价于两个指针之间的地址差除以 sizeof(int),即 4 / 4 = 1

指针的大小与限制

1. 指针的大小统一

所有指针的大小相同,因为它们都存储内存地址。但是不同的指针类型之间不能互相赋值,例如 int *p = (char*)0x12345678; 会导致类型错误。

2. 指针的有效使用

指针只能在动态分配的内存区域内使用,避免越界操作,以免导致程序崩溃或者数据丢失。


指针的主要用途

  • 传递大型数据时,尤其是机器型数据,利用指针可以减少内存占用。
  • 传递数组或结构体时,使用指针可以避免分配过多内存。
  • 返回多个返回值时,通过指针数组保存返回数据。
  • 动态分配内存以应对需求变化,比如使用 malloccalloc 函数。

通过对指针的操作,我们能够方便地在内存中定向存取和操作数据,这为程序开发提供了极大的灵活性。

转载地址:http://lkakk.baihongyu.com/

你可能感兴趣的文章
Numpy矩阵与通用函数
查看>>
numpy绘制热力图
查看>>
numpy转PIL 报错TypeError: Cannot handle this data type
查看>>
Numpy闯关100题,我闯了95关,你呢?
查看>>
Nutch + solr 这个配合不错哦
查看>>
NutUI:京东风格的轻量级 Vue 组件库
查看>>
NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
查看>>
NutzWk 5.1.5 发布,Java 微服务分布式开发框架
查看>>
NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
查看>>
NuxtJS 接口转发详解:Nitro 的用法与注意事项
查看>>
NVelocity标签使用详解
查看>>
NVelocity标签设置缓存的解决方案
查看>>
Nvidia Cudatoolkit 与 Conda Cudatoolkit
查看>>
NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
查看>>
NVIDIA-cuda-cudnn下载地址
查看>>
nvidia-htop 使用教程
查看>>
nvidia-smi 参数详解
查看>>
Nvidia驱动失效,采用官方的方法重装更快
查看>>
nvm切换node版本
查看>>
nvm安装以后,node -v npm 等命令提示不是内部或外部命令 node多版本控制管理 node多版本随意切换
查看>>