- 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 - Foundation 框架
- 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
广告