美文网首页
GeekBand之C++面向对象高级编程(下)第二周笔记

GeekBand之C++面向对象高级编程(下)第二周笔记

作者: 易班熊 | 来源:发表于2016-06-12 17:32 被阅读0次
C++程序设计(Ⅱ)
提醒:勿在浮沙筑高台
泛型编程和面向对象编程是C++的技术主线
深入探索面向对象之继承关系所形成的对象模型(Object Model),包括隐藏于底层的this指针,vptr(需指针),vtbl(虚表),virtual mechanism(需机制),以及虚函数(virtual functions) 造成的polymorphism(多态)效果。
2.Conversion Function 转换函数
operator function_name() const{return ......}operator 是关键字,不可以有参数 且不写返回值,另外,函数名称是一种数据类型且通常+ const。 3.non-explicit-one-argument ctor只要一个实参就够了,
explicit --意思是明白的,明确的 告诉编译器不要进行隐式操作。一般在构造函数前面。
typedef 类型 重命名
4.pointer-like classes,关于智能指针,智能指针必然是一个class。     一个智能指针一定是一个类,数据成员至少有一个指针成员和若干操作方法。操作方法中一定有->操作符重载和*操作符重载,用于获取成员指针和成员指针指向的内容(或对象)5.pointer-like classes ,关于迭代器     迭代器代表容器【vector】中一种元素,因此它也可以看作为一个智能指针。也就是创建一个class 模拟pointer功能。
6.function-like classes,所谓仿函数     创建一个class,用来模拟function,因此需要对操作符()重载。 类似这些class创建出来的对象都是 “函数对象”或称为“仿函数”
7.namespace 经验谈     将一些变量、函数等封装到一个namespace里面,类似划区间分类的感念。
8.class template,类模板     template<typename T>     在你设计类的时候,你考虑可以把哪些类型抽出来,好动态传递,使得创建的类具备通用性。     在创建类模板对象时,一定要指定模板类型例如,complex<double>c1(2.5,1.5)
9.function template ,函数模板     函数模板在使用时,不必指定数据类型。例如,min(r1,r2);原因在于编译器会进行实参推导(argument deduction)
10.member template,成员模板     一个成员是一个模板的成员,而这个成员本身也是一个模版,那么我们就称这个成员为成员模板。个人理解是模板嵌套。     up-cast      允许子类指针指向父类对象。          11.specialization,模板特化     什么叫泛化:就是使用模板template进行设计类和函数。     什么叫特化:为了某些独特的类型进行特殊的设计。     12.partial specialization,模板偏特化     也叫局部特化,有两种形式:     【个数上的偏】,例如,模板参数有N个,如果此时你想绑定某一个参数类型。且绑定顺序一定是连续的。     【范围上的偏】,由原来的任意数据类型,缩小到例如,任意类型指针且必须是指针类型。
13.template template parameter,模板模板参数     
下面的截图不是模板模板参数
  1. 关于C++标准库
          对于初学者一定要熟悉它,多使用它。          容器Sequence Containers                         array                         vector                         deque                         forward_list                         list               Container adaptors:                         stack                         queue                         priority_queue
          算法Algorithms                Sorting:                         sort                         stable_sort                         partial_sort                         partial_sort_copy                         is_sorted                         is_sorted_until                         nth_element
               Binary search                         lower_bound                         upper_bound                         equal_range                         binary_search                    Merge(operating on sorted)                         merge                         inplace_merge                         includes                         set_union                         set_intersection                         set_difference                         set_symmetric_difference                         ......     不要眼高手低,尽量测试这些数据结构和算法。

auto 语法糖以前:list<string> c;...list<string>::iterator ite;ite = find(c.begin(),c.end(),target);
现在:list<string>c;...auto ite =find(c.begin(),c.end(),target);

ranged-base forfor(decl:coll){     statement}//decl 可以是一个变量,coll必须是一个容器例如,for(int i:{2,3,4,5,6,9}){     cout <<i<<endl;} 动态绑定或虚机制: 必要条件: 1.必须要是指针 2.向上转型 3.调用的是虚函数
静态绑定:通过地址直接访问。
对象模型:关于this
在C++中所有成员函数都有一个隐藏的this指针。
有关new 、delete new:先分配memory,再调用ctor delete:先调用dtor,再释放memory array new 一定要搭配array delete      例如,String* p = new String[3];                delete[] p;//唤醒3次dtor

重载::operator new ,::operator delete       ::operator new[],::operator delete[]



相关文章

网友评论

      本文标题:GeekBand之C++面向对象高级编程(下)第二周笔记

      本文链接:https://www.haomeiwen.com/subject/mjnedttx.html