iOS 程序中的内存地址

  1. 成员变量的内存地址分配
    // - 对象的内存地址分配图
    在这里插入图片描述
// - 1. 查看成员对象的定义
@interface MJPerson : NSObject

/** 年龄 */
@property(nonatomic, assign)int age;

/** 身高 */
@property(nonatomic, assign)int hei;

/** 体重 */
@property(nonatomic, assign)int wei;

@end

// - 2. 对象的赋值
MJPerson *person = [[MJPerson alloc] init];
person.age = 1;
person.hei = 2;
person.wei = 3;

// - 3. 对象的内存地址分配情况
person 地址 : 0x600000b9cea0
person->isa 地址 : 0x600000b9cea0  (person->isa : 指向 Person 这个类的内存地址)
person-> age 地址: 0x600000b9cea8
person-> hei 地址: 0x600000b9ceac
person->wei 地址: 0x600000b9ceb0

[结论]: 由上边的图和代码可知 对象的成员变量在内存中地址是连续的 并且是由低地址->高地址的

  1. 函数调用栈中的内存地址分配
    // - 函数调用栈的内存地址分配图
    在这里插入图片描述
// - 1. 查看函数的实现
@implementation MJPerson

/** 方法定义 */
- (int)test:(int)age height:(float)height
{
    NSLog(@"%s", __func__);
    int a = 3;
    int b = 4;
    int c = 5;
    return 0;
}

@end

// - 2. 查看函数的调用方式
[person test:1 height:2];

// - 3. 查看函数的内存分布
person 地址: 0x7ffee73dbf18
_cmd 地址 : 0x7ffee73dbf10
age 地址 : 0x7ffee73dbf0c
height 地址 : 0x7ffee73dbf08
a 地址: 0x7ffee73dbf04
b地址: 0x7ffee73dbf00
c 地址: 0x7ffee73dbefc

[结论]: 由上边的图和代码可知 函数栈中的变量在内存中的分布是连续的, 并且地址是由高地址->低地址的

[堆区, 栈区, 常量区的内存地址] :
堆区 : 0x6***
栈区 : 0x7***
常量区 静态变量区 : 0x1****

iOS 中数据宽度

    int c = 0xFFFFFFFFFFFFFFFD;
    int d = c+1;
    int d1 = c+2;
    int d2 = c+3;
	c = -3, d = -2, d1 = -1, d2 = 0;	

下图所示 32 位机器中数据宽度模型. 0 ~ 0x7FFFFFFF为正数且递增, 0xF0000000 ~ 0xFFFFFFFF 为负数且递增(0xFFFFFFFD = -3, 0xFFFFFFFE = -2, 0xFFFFFFFF = -1, 0xFFFFFFFF + 1 = 0), 有符号的时 最大的正数(0x7FFFFFFF) + 1 = 最小的负数(0xF0000000), 最大的负数(0xFFFFFFFF) + 1 为最小的正数(0).
在这里插入图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值