一.explicit 关键字 有什么作用
首先要了解这几个概念:
a .隐式转换:凡是在语境中使用了某种类型 T1
的表达式,但语境不接受该类型而接受另一类型 T2
的时候,会进行隐式转换。
b.转换构造函数
声明时不带函数说明符 explicit 的拥有单个无默认值形参的(C++11 前)构造函数被称作转换构造函数。
c.复制初始化
从另一个对象初始化对象。
class Cube
{
public:Cube(double side) :m_side(side){std::cout << "cube Constructed called...";}
};
次构造函数称为转换构造函数。
因为 explicit:
1) 指定构造函数或转换函数(C++11 起)或推导指引(C++17 起)为显式,即它不能用于隐式转换和复制初始化。
//demo2
#if 1
class Cube
{
public:/*explicit*/ Cube(double side) :m_side(side){std::cout << "cube Constructed called...";}double volume() { return m_side * m_side * m_side; }bool hasLargerVolumethan(Cube c2){return volume() > c2.volume();}private:double m_side;
};
int main()//
{Cube c1(7);if (c1.hasLargerVolumethan(50))//使用者想用50作为c2体积,结果被识别为 构造函数中的形参{std::cout << "c1体积大于50";}else{std::cout << "c1体积小于50";}//因此为避免隐式转换的歧义,构造函数前加入explicit关键字防止隐式类型转换return 0;
}
#endif
在调用if (c1.hasLargerVolumethan(50))代码时会调动C1类型的构造函数,因为没有声明explicit关键字导致的隐式转换。
以下是复制初始化在explicit关键字显示声明的情况下失效的例子:
struct B
{explicit B(int) {}explicit B(int, int) {}explicit operator bool() const { return true; }
};
int main()
[// B b1 = 1; // 错误:复制初始化不考虑 B::B(int)B b2(2); // OK:直接初始化选择 B::B(int)B b3 {4, 5}; // OK:直接列表初始化选择 B::B(int, int)
// B b4 = {4, 5}; // 错误:复制列表初始化不考虑 B::B(int,int)
}
二.vector扩容方式
三.list forwad_list 区别
四.迭代器失效
vector list 各自介绍迭代器是否会失效
五.智能指针
六.lambda 表达式
七.你了解过什么设计模式
八.thread_Local
九.std::function