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

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 for
for(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[]




最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容