标签:tmp std cout dynamic cast static Print
#include <iostream>
class F
{
public:
F() {}
//virtual ~F() {}
virtual void Print()
{
std::cout << "F::Print()" << std::endl;
}
};
class S : public F
{
public:
S() {}
~S() {}
void Print()
{
std::cout << "S::Print()" << std::endl;
}
public:
int tmp_ = 0;
};
int main()
{
S s;
F f;
//向下转型,由父变子
S* s1 = dynamic_cast<S*>(&f);
//此处s1为nullptr,表明dynamic_cast有提升安全的功能,故不会进入条件语句中。
//因为此处f指向的是基类,而非某个具体的派生类,仅和下面static_cast作对比测试
if (s1)
{
s1->Print();
std::cout << s1->tmp_ << std::endl;
}
//S* s2 = static_cast<S*>(&f);
//向下转型static_cast没有安全检测,会进入到下方条件语句中,在输出子类tmp_时抛出异常
//if (s2)
//{
//s2->Print();
//std::cout << s1->tmp_ << std::endl;
//}
//正常的向下转型应用场景:当知晓父类的指针指向了某一个子类的对象时,调用转换函数,进行转换
F* f3 = new S();
S* s3 = dynamic_cast<S*>(f3);
if (s3)
{
s3->Print();
std::cout << s3->tmp_ << std::endl;
}
//向上转型 虚函数表找到子类重写过的虚函数,实则为子类对象调用
F* f1 = dynamic_cast<F*>(&s);
if (f1)
{
//父类指针其实指向了该子类对象
f1->Print();
}
//向上转型static_cast和dynamic_cast效果一样
F* f2 = static_cast<F*>(&s);
if (f2)
{
f2->Print();
}
return 0;
}
//输出结果如下
//S::Print()
//0
//S::Print()
//S::Print()
标签:tmp,std,cout,dynamic,cast,static,Print 来源: https://blog.csdn.net/weixin_42734445/article/details/120676343
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。