boost::implicit_cast
Posted gccbuaa
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了boost::implicit_cast相关的知识,希望对你有一定的参考价值。
在C++中有四种类型转换
1、static_cast:这个是最经常使用的类型转换。凡是C++隐式执行的类型转换都能够用static_cast显式完毕。在隐式转换时有时编译器会有警告信息。可是显示转换就不会有。
2、const_cast:从名字能够看出和const有关,这个转换的作用是去除或加入const特性,它能够将一个const变量转换为非const变量,或将一个非const变量转换为const变量。
3、dynamic_cast:这个是执行时检查该类型转换是否安全。被转换的类型必须是多态(即有虚函数)。具体可參考这里
4、interpret_cast:interpret意思为又一次解释。意思为将数据的二进制格式又一次解释,它依赖机器。
在boost库中有个implicit_cast。这个表示“隐式”转换,即能够隐式转换的地方才干够用它。
以一个样例说明,在菱形继承中。最底层的对象能够转换为中层对象
#include<boost/implicit_cast.hpp>
#include<iostream>
class Top{};
class MiddleA:public Top{};
class MiddleB:public Top{};
class Bottom:public MiddleA,public MiddleB{};
void Function(MiddleA& A)
{
std::cout<<"MiddleA Function"<<std::endl;
}
void Function(MiddleB& B)
{
std::cout<<"MiddleB Function"<<std::endl;
}
int main()
{
Bottom bottom;
Function(bottom);
return 0;
}
这时假设编译,就会出现错误。由于在调用函数Function时。bottom既能够默认转换为MiddleA,也能够默认转换为MiddleB,假设不明白指出就会出现歧义。这时能够改为:
Function(static_cast<MiddleA&>(bottom));
或
Function(static_cast<MiddleB&>(bottom));
程序能够执行了。可是假设不小心这样使用了:
Top top;
Function(static_cast<MiddleB&>top);
这样编译能够通过,可是在执行时能够崩溃。由于top不是“一种”MiddleB。可是编译器不能发现这个问题。这时假设用implicit_cast就不会有这个问题了,在编译时就会给出错误信息。
在转换时up-cast不会有问题,由于派上类就是一种基类。它包括基类全部信息。可是基类不是一种派上类。假设down-cast就可能有问题。
static_cast比較强大,能够执行上述两种转换。
可是implicit_cast比較弱一点,仅仅能执行up-cast。
以上是关于boost::implicit_cast的主要内容,如果未能解决你的问题,请参考以下文章