只有一点汇编和C语言基础跑来学习GeekBand的IOS微专业,还真是有点不自量力的感觉,不过听课听下来发现这些基础刚好够用,尤其是汇编的基础对理解李建忠老师的内存分析派说法很有用,敲代码的时候时刻思考这三个经典问题:
数据从哪里来?
数据进行了什么处理?
数据到哪里去?
第一节课介绍了一些OC语言相关,就不记录了。
第二节课介绍了类与对象的概念、类对象与实例(值)的对比、栈与堆的概念。这堂课有一个非常重要的内容,就是类对象和实例(值)的存储方式是不一样的。类将自己的指针存在栈中,然后指针指向存在堆中的真正内容;值直接将自己的内容保存在栈中。
第三节课介绍了一个类应该具有哪些成员并详细地讨论了属性和实例变量的含义和区别,尤其是在编译层面对属性和实例变量的讨论有一定深度。
首先一个类包含两大成员:数据成员(描述对象状态)、函数成员(描述对象行为)。其中数据成员包括属性(对外)、实例变量(对内);函数成员包括方法(用以处理数据)、初始化器、析构器(用以释放数据)。
其次,属性在定义的时候,通常编译器会自动合成getter访问器(用以访问数据)和setter访问器(用以修改数据)以及一个实例变量。这些也可以自定义。
最后,课程介绍了属性的几种特性,并在内存模型层面再一次对比了值实例变量与对象的区别,并浅谈了ARC内存释放机制(以引用计数的方式来判断是否释放内存,计数为0时释放)。
第四节课详细介绍了方法的概念,有意思的是调用方法时称之为向对象“发消息”,我是这样理解的:对象在自己的消息分发表中保存了自己所有方法的入口,我们给对象“发消息”就是让对象去选择某一个方法来处理自身的相关数据。这似乎和C语言有很大差别?C语言中我如果定义了一个函数,就可以用来处理任何可以处理的数据,似乎具有很大的全局性。而方法只能处理对象自身的数据?所以调用方法才称之为向对象“发消息”么?
当课程中提到实例方法和类方法的区别时,更进一步加深了我对“发消息”这个说法的认可。与其说“发消息”,不如说是“下命令”。
接着需要注意方法的命名规则和调用规则,对于我这种新人来说看着这规则还好,因为本来其他计算机语言的基础都还没打牢呢,没有熟悉到爆炸的规则,啥规则对我来说都跟新的一样= =
最后讲到的消息分发表,让我想起了汇编里面的中断向量表,他们都是将处理数据的具体代码的入口地址以列表的形式保存在一起,好吧,它们有个毛线的关系= =
第五节课详谈了初始化器和析构器,首先要清楚的是,它们都是特殊的方法。对象初始化器init通常与alloc搭配使用,如[Animal alloc] init]这种,先给Animal发一个alloc的消息(在堆上分配内存,并将内存置0(注:地址也置为全0)),处理完数据后再发一个init的消息。
有一点要注意,自定义init时一定要先调用父类的初始化器,如[super init]一定要写在定义init的首要位置。
然后,对象析构器dealloc负责释放对象占有的动态内存,其中内容分三部分,ARC自动实现的部分、手动实现的不受ARC控制的部分、手动实现关闭非内存资源。需要注意的是,dealloc会在最后自动调用父类的dealloc,不需要手动添加这段代码。
第六节课介绍了继承的概念,这堂课我印象最深的就是那啥,NSObject也叫做祖先类= =是所有类的祖先...
每个类必须有且仅有一个基类(得有一个爸爸,而且强调只能有一个= =),基类也叫做父类,每个类相对于父类来说称为子类。每个子类都会继承父类的实例变量、属性、实例方法、类方法。(注:由于初始化器和析构器都是特殊的方法,所以子类也会继承父类的初始化器和析构器。)
还有就是继承的内存模型,子类在创建的时候,相当于是在子类指针指向的堆上先完整的复制了父类的代码,再在后面添加自己的代码,因此就不难解释继承的含义了,不过有意思的是,父类的消息分发表中各方法的入口地址似乎没有继承,子类在创建的时候在堆上分配了新的空间,复制了所有父类方法的代码,因此子类的消息分发表中的各方法入口就指向了新的空间,这就不难解释讨论多态机制时子类方法重写的问题。
最后第七节课主要讨论了多态的机制,首先要确定的是子类的方法不支持重载(重新在子类实现文件中按照方法名相同、参数不同的形式定义父类的方法)。
其次,self和super是不同的,self可以指向不同的子类(看是谁在调用),而super仅指向当前的父类(“来,到爸爸这里来”)。这个很重要,尤其在父类的初始化器和析构器中,尽量不要用到self,免得到时候连自己是谁都不知道233 。
就写这么多吧,脑子里只能想到这么多了,反正也就只是写给自己以后翻翻看的= =还有,简书这网站不错啊,对于我这种上一次写文章还是在十年前的QQ空间的人来说,这网站让我码字停不下来的节奏233