1. 内存中的五大区域.
栈: 存储局部变量.
堆: 程序员手动申请的字节空间 malloc calloc realloc函数.
BSS段: 存储未被初始化的全局变量 静态变量.
数据段(常量区): 存储已被初始化的全局 静态变量 常量数据.
代码段: 存储代码. 存储程序的代码.
对象在内存中存储的过程:
Person *p1 = 【【Person alloc】init】;
1). Person *p1; 会在栈内存中申请1块空间. 在栈内存中声明1个Person类型的指针变量p1。
p1是1个指针变量. 那么只能存储地址.
2). [Person new]; 真正在内存中创建对象的其实是这句代码.
new做的事情
a. 在堆内存中申请1块合适大小的空间.(相当于alloc)
b. 在这个空间中根据类的模板创建对象.
类模板中定义了什么属性.就把这些属性依次的声明在对象之中.
对象中还有另外1个属性 叫做isa 是1个指针. 指向对象所属的类在代码段中的地址.
c. 初始化对象的属性 (相当于init)
如果属性的类型是基本数据类型 那么就赋值为0
如果属性的类型是C语言的指针类型 那么就赋值为NULL
如果属性的类型是OC的类指针类型 那么就赋值为nil
d. 返回对象的地址.
3). 注意
a. 对象中只有属性,而没有方法. 自己类的属性外加1个isa指针指向代码段中的类.
b. 如何访问对象的属性
指针名->属性名;
根据指针 找到指针指向的对象 再找到对象中的属性来访问.
c. 如何调用方法.
[指针名 方法名];
先根据指针名找到对象,对象发现要调用方法 再根据对象的isa指针找到类.
然后调用类里的方法.
4. 为什么不把方法存储在对象之中?
因为每1个对象的方法的代码实现都是一模一样的 没有必要为每1个对象都保存1个方法 这样的话就太浪费空间了.
既然都一样 那么就只保持1份.
5. 对象的属性的默认值.
如果我们创建1个对象,没有为对象的属性赋值. 那么这个对象的属性是有值的.
如果属性的类型是基本数据类型 默认值是0
如果属性的类型是C指针类型 那么默认值是NULL
如果属性的类型是OC指针类型 那么默认值是nil