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。

你可能感兴趣的:(C语言,boost)