oc对象可以调用class方法看下这个对象的类型!!!所以block也是可以的
所以实例对象调用superclass方法和类对象调用superclass方法返回的值是一样的,都是该类的父类对象!!!
因为我们程序都是跑在内存中,那内存中放的是什么东西,那它真正的结果就是什么东西!!!一切是以运行时结果为准,也就是说block在内存中确实有以上三种类型~
text段放代码--我们俗称代码段!代码段的内存地址值一般来说是比较小的,也就是比较前面。平时我们自己写的代码,一般都放在text段也就是代码段。
越往下内存地址值越大!
data段--就是数据段,一般用来存放全局变量,
比如上图中的age
堆区:是动态分配内存的,比如我们平时alloc出来的对象就是放在堆区,一旦调用alloc,就需要动态分配内存。堆区的特点,就是需要我们程序员自己写些代码去申请内存,
---堆动态分配内存,需要程序员自己申请内存,也需要程序员自己管理内存。
栈区放一些局部变量,或者函数参数,特点是系统自动分配内存,也会自动销毁内存,当局部变量离开大括号,离开作用域就会自动销毁。
text段和数据段也不需要我们管,是编译器决定好的。我们这个代码一旦编译成功,就会自动把代码和全局变量分别放到代码段和数据段,程序一启动,就会把我们的代码和全局变量那些数据搬到内存中来。
全局block跟全局变量放一起,堆block放在堆区,跟一般的oc对象是一样的,堆block的内存需要程序员自己去销毁。栈block放在栈区,栈block的内存会自动销毁!!!
访问auto变量的block是栈block,栈block的内存放在栈上,既然栈block的内存放在栈上,当test2这个函数调用完毕的时候,那这个函数栈上的一些东西就有可能被销毁了,一旦销毁的话,就肯定会影响到block内部的一些东西,这样的话,虽然block是个全局变量,外面能访问,但真正在去执行block里面那份代码的话,就出现混乱了。上图中的栈block是放栈的,既然block的内存是放栈上的,那test2这个函数调用完,test2函数栈要销毁了,那block结构体里面存储的数据可能变成垃圾数据了(这种可以理解为以前我们写通知的时候,在不用的时候,需要移除通知的原理一样。因为通知中心会保存对应对象的内存地址,当对象的内存地址销毁后,还拿通知中心保存的对象地址去访问对象原先的内存地址的时候,就会出现野指针错误,所以不用的时候要移除通知)
全局block调用copy之后还是全局block,栈block调用copy变成堆block!!!
ARC环境下,如果block使用copy修饰的,上图中给person的blcok赋值, ^{}会自动调用copy!
函数调用栈就是你要调用这个函数的时候,就会指定一块栈区空间给你这个函数用,专门给你这个函数用,但是你这个函数一旦调用完毕以后,栈区这块空间就会回收,也相当于变成垃圾数据,以后会给别人用,会被别人给覆盖。
在函数外面定义的变量称为全局变量,在函数里面定义的变量称为局部变量。