模板
类型参数化,编写代码时可以忽略类型
template <typename T>//告诉编译器,下面写的是模板函数(只对后面第一个函数或第一个类生效)
模板函数
1、自动类型推导,编译器根据实参数类型,自动推导
2、显式指定类型 fun<int>();//指定类型int
函数模板不能进行自动类型转换,函数模板必须精准类型匹配
c++编译器优先考虑普通函数
调用的时候生成具体的函数
类模板
类模板必须显式指定类型
写类模板是声明和实现放在一个头文件中,后缀改为hpp
类模板遇到static成员时不同类型类共享各自的静态成员变量
类型转换
强制类型转换Type b = (Type) a;
static_cast(一般的转换,内置数据类型和具有继承关系的指针或者引用),dynami_cast(通常在基类和派生类之间转换使用,在转换前会进行安全检查),const_cast(主要针对const的转换,增加或减少变量的const性),reinterpret_cast(强制类型转换)
异常机制
throw y;//抛出异常
try{ } catch(异常类型){ }//异常是根据异常类型匹配的
异常接口声明
catch(...){}捕获所有异常
throw()//不能抛出任何类型的异常
异常用指针接收时要注意参数的生命周期
cout和cin是全局流对象,cerr标准错误输出,clog标准日志输出
文件读写
1、ifstream ism(filename,ios::in);//只读方式打开文件.2、ifstream ism;ism.open(filename,ios::in);
ofstream osm(filename,ios::out);//写文件
stl提供容器、算法、迭代器
vector用at访问出现数组越界时会抛出异常,[]访问时出现数组越界时则不会
vector中reserve作用:预留空间
deque容器双端队列
set和map容器都是以红黑树为底层实现机制
函数对象可以保存函数调用的状态
仿函数适配器
移动构造函数是C++11引入的一种新的构造函数,它接收右值引用。与拷贝构造函数和拷贝赋值运算符一样,除了移动构造函数之外,C++11还引入了移动赋值运算符。移动赋值运算符也是接收右值引用。