写在这次笔记之前
这次课程说实话有些东西太过抽象,对于老师的讲解有相当多地方不能完全理解。但我认为这次课主要还是讲解了一些思想方法,是之前结构化变编程未思考过的,并没有讲解过多新的语法。(当然有虚函数的新知识)对于我来说,语法的东西多编译几次。多搜索都是可以解决的,但是思想方法确实不好在多写程序的过程里建立起来,这需要多看,多读,多想,参考前人对于此类问题的思维模式。所以,这次笔记没有再去着重划出重点,因为明显的都需要认真掌握。
组合与继承
1.Adaptor:一种设计模式:已有一种“类”满足现在所需功能,再设计一个adaptor来将其“改头换面”来用。
2.Composition(复合)关系的构造和析构:构造由内而外,container先调用component的default(默认)构造函数,再执行自己。析构由外而内。里外生命周期一致。
3.Delegation(委托)或称(Composition
by reference):类里有个指针指向另一个类。里外生命周期不一致。称之为“编译防火墙”,外层不需再编译。
4.Copy on right:共享一个内容时,其中一个要改动内容,就拷贝一份让它改,剩下的再共享那一个。
5.Inheritance(继承):类名后跟:和继承类型,以及继承类的名称。父类的数据完全被继承下来。(?)
6.继承关系下的构造和析构:父类(base class)的析构函数必须要是virtual,否则会出现undefined behavior。构造也是由内而外。先调用父类的默认构造函数。析构由内而外,先调用子类的析构函数,再调用父类的析构函数。
虚函数与多态
1.Struct也可以用继承
2.虚函数:函数前加virtual即是虚函数。你希望子类重新定义这个函数,但有默认定义。virtual void draw() const = 0;这是纯虚函数,对它没有默认定义(其实可以有?),子类一定要重新定义。(当然那个const不是纯虚函数定义的一部分)
3.一种想法:操作出错,可以抛出一个错误信息,写个virtual void error(const std::string& msg);
4.空函数不是纯虚函数,子类可以不重写。
5.通过子类对象调用父类函数。
6.Template Method:先把固定部分写好,留下无法固定的部分写成virtual。(MFC?)
7.继承和复合关系下的构造和析构:①子类有复合?(待测试)②父类有复合,先复合,再父类,最后子类。析构倒过来。
(测试结果,先父类,再复合,最后子类)
(贴出测试代码:
#include
usingnamespace std;
classbase
{
public:
base(){cout<<"basector"<
};
classcomponent
{
public:
component(){cout<<"componentctor"<
};
classderived:public base
{
private:
component A;
public:
derived(){cout<<"derivedctor"<
};
intmain()
{
derived test;
return 0;
}
)8.委托+继承功能最强大:例如:一个“主题”开好多“观察者”来观察它,观察者可以继承。(?没从课件中体会到为何这样最强大)
委托相关设计
1.(?老师讲设计模式的时候一脸懵逼)composite
2.Prototype:创建未来用的class?子类自己创造自己(静态)。子类有个构造函数“挂到上面”?
3.个人理解:prototype是在父类里,子类把自己放在这里可以让父类调用。
课后疑问:在笔记里标出了一些?,那是我有疑问的地方,希望看到我的笔记的同学能帮助我解答一下,将感激不尽。
老师讲解的设计模式,没有从老师的例子例感受到它们的功能强大。只是感觉比较巧妙,不知诸如prototype和adaptor这样的设计模式将来会在什么地方用到。
网友评论