- 基本 Objective-C
- Objective-C - 主页
- Objective-C - 概述
- Objective-C - 环境设置
- Objective-C - 程序结构
- Objective-C - 基本语法
- Objective-C - 数据类型
- Objective-C - 变量
- Objective-C - 常量
- Objective-C - 运算符
- Objective-C - 循环
- Objective-C - 决策
- Objective-C - 函数
- Objective-C - 块
- Objective-C - 数字
- Objective-C - 数组
- Objective-C - 指针
- Objective-C - 字符串
- Objective-C - 结构
- Objective-C - 预处理器
- Objective-C - Typedef
- Objective-C - 类型转换
- Objective-C - 日志处理
- Objective-C - 错误处理
- 命令行参数
- 高级 Objective-C
- Objective-C - 类和对象
- Objective-C - 继承
- Objective-C - 多态性
- Objective-C - 数据封装
- Objective-C - 类别
- Objective-C - 摆姿势
- Objective-C - 扩展
- Objective-C - 协议
- Objective-C - 动态绑定
- Objective-C - 复合对象
- Obj-C - 基础框架
- Objective-C - 快速枚举
- Obj-C - 内存管理
- Objective-C 有用资源
- Objective-C - 快速指南
- Objective-C - 有用的资源
- Objective-C - 讨论
Objective-C - 指针算术
正如主要章节中所解释的,Objective-C 指针是一个地址,它是一个数值。因此,您可以像对数值一样对指针执行算术运算。可以在指针上使用四种算术运算符:++、--、+ 和 -
为了理解指针算术,让我们假设ptr是一个整数指针,它指向地址 1000。假设是 32 位整数,让我们对指针执行以下算术运算 -
ptr++
现在,经过上述操作,ptr将指向位置 1004,因为每次 ptr 递增时,它将指向下一个整数位置,即当前位置旁边的 4 个字节。此操作会将指针移动到下一个内存位置,而不影响该内存位置的实际值。如果ptr指向地址为1000的字符,那么上面的操作将指向位置1001,因为下一个字符将在1001处可用。
增加一个指针
我们更喜欢在程序中使用指针而不是数组,因为变量指针可以递增,而数组名则不能递增,因为它是常量指针。以下程序递增变量指针以访问数组的每个后续元素 -
#import <Foundation/Foundation.h> const int MAX = 3; int main () { int var[] = {10, 100, 200}; int i, *ptr; /* let us have array address in pointer */ ptr = var; for ( i = 0; i < MAX; i++) { NSLog(@"Address of var[%d] = %x\n", i, ptr ); NSLog(@"Value of var[%d] = %d\n", i, *ptr ); /* move to the next location */ ptr++; } return 0; }
当上面的代码被编译并执行时,它会产生如下结果 -
2013-09-14 00:08:36.215 demo[32000] Address of var[0] = 7e6f2a70 2013-09-14 00:08:36.216 demo[32000] Value of var[0] = 10 2013-09-14 00:08:36.216 demo[32000] Address of var[1] = 7e6f2a74 2013-09-14 00:08:36.216 demo[32000] Value of var[1] = 100 2013-09-14 00:08:36.216 demo[32000] Address of var[2] = 7e6f2a78 2013-09-14 00:08:36.216 demo[32000] Value of var[2] = 200
减少指针
同样的考虑因素也适用于递减指针,即按其数据类型的字节数减少其值,如下所示 -
#import <Foundation/Foundation.h> const int MAX = 3; int main () { int var[] = {10, 100, 200}; int i, *ptr; /* let us have array address in pointer */ ptr = &var[MAX-1]; for ( i = MAX; i > 0; i--) { NSLog(@"Address of var[%d] = %x\n", i, ptr ); NSLog(@"Value of var[%d] = %d\n", i, *ptr ); /* move to the previous location */ ptr--; } return 0; }
当上面的代码被编译并执行时,它会产生如下结果 -
2013-09-14 00:12:22.783 demo[13055] Address of var[3] = ea4c618 2013-09-14 00:12:22.783 demo[13055] Value of var[3] = 200 2013-09-14 00:12:22.783 demo[13055] Address of var[2] = ea4c614 2013-09-14 00:12:22.783 demo[13055] Value of var[2] = 100 2013-09-14 00:12:22.783 demo[13055] Address of var[1] = ea4c610 2013-09-14 00:12:22.783 demo[13055] Value of var[1] = 10
指针比较
可以使用关系运算符(例如 ==、< 和 >)来比较指针。如果p1和p2指向彼此相关的变量,例如同一个数组的元素,那么p1和p2可以进行有意义的比较。
以下程序通过递增变量指针来修改前面的示例,只要它指向的地址小于或等于数组最后一个元素的地址,即 &var[MAX - 1] -
#import <Foundation/Foundation.h> const int MAX = 3; int main () { int var[] = {10, 100, 200}; int i, *ptr; /* let us have address of the first element in pointer */ ptr = var; i = 0; while ( ptr <= &var[MAX - 1] ) { NSLog(@"Address of var[%d] = %x\n", i, ptr ); NSLog(@"Value of var[%d] = %d\n", i, *ptr ); /* point to the previous location */ ptr++; i++; } return 0; }
当上面的代码被编译并执行时,它会产生如下结果 -
2013-09-14 00:15:49.976 demo[24825] Address of var[0] = ae1235a0 2013-09-14 00:15:49.976 demo[24825] Value of var[0] = 10 2013-09-14 00:15:49.977 demo[24825] Address of var[1] = ae1235a4 2013-09-14 00:15:49.977 demo[24825] Value of var[1] = 100 2013-09-14 00:15:49.977 demo[24825] Address of var[2] = ae1235a8 2013-09-14 00:15:49.977 demo[24825] Value of var[2] = 200
Objective_c_pointers.htm