草庐IT

production_cast

全部标签

c++ - dynamic_cast 是如何工作的?

如果您有以下情况:classAnimal{};classBird:publicAnimal{};classDog:publicAnimal{};classPenguin:publicBird{};classPoodle:publicDog{};dynamic_cast是否只检查一个类是否是另一个类的派生类,或者一个类是否是另一个类的基类?所以如果我有:Bird*bird;Animal*animal;bird=dynamic_cast(bird);animal=dynamic_cast(animal);bird现在将指向一个Animal类,这样我就可以使用bird->some_funct

c++ - dynamic_cast 是如何工作的?

如果您有以下情况:classAnimal{};classBird:publicAnimal{};classDog:publicAnimal{};classPenguin:publicBird{};classPoodle:publicDog{};dynamic_cast是否只检查一个类是否是另一个类的派生类,或者一个类是否是另一个类的基类?所以如果我有:Bird*bird;Animal*animal;bird=dynamic_cast(bird);animal=dynamic_cast(animal);bird现在将指向一个Animal类,这样我就可以使用bird->some_funct

c++ - 如何使用 dynamic_cast 运算符识别失败的强制转换?

ScottMeyer在他的书EffectiveC++中说dynamic_cast用于执行向下或跨继承层次结构的安全转换。也就是说,您使用dynamic_cast将基类对象的指针或引用转换为派生或同级基类对象的指针或引用,这样您就可以确定转换是否成功。失败的转换由空指针(转换指针时)或异常(转换引用时)指示。我想得到两个代码片段,在可以指示转换指针和转换引用的情况下显示失败的转换。 最佳答案 对于指针,这是一个简单的空检查:A*a=newA();B*b=dynamic_cast(a);if(b==NULL){//Castfailed}

c++ - 如何使用 dynamic_cast 运算符识别失败的强制转换?

ScottMeyer在他的书EffectiveC++中说dynamic_cast用于执行向下或跨继承层次结构的安全转换。也就是说,您使用dynamic_cast将基类对象的指针或引用转换为派生或同级基类对象的指针或引用,这样您就可以确定转换是否成功。失败的转换由空指针(转换指针时)或异常(转换引用时)指示。我想得到两个代码片段,在可以指示转换指针和转换引用的情况下显示失败的转换。 最佳答案 对于指针,这是一个简单的空检查:A*a=newA();B*b=dynamic_cast(a);if(b==NULL){//Castfailed}

C++ 使用 "this"对象的 static_cast 和 const_cast 添加 const-ness 之间的区别?

按照ScottMeyers的说法,为防止在getter的const版本和getter的非常量版本中重复代码,请从非常量版本调用方法的const版本:static_cast(*this).Methodology();然而,由于过度使用VisualAssistXIntellisense导致意外使用,我输入了:const_cast(*this).Methodology();而且效果很好。在这种情况下,使用特定类型转换有什么不同?使用的IDE:VisualStudio2010。 最佳答案 假设this的类型是A*,没有区别。通常const_

C++ 使用 "this"对象的 static_cast 和 const_cast 添加 const-ness 之间的区别?

按照ScottMeyers的说法,为防止在getter的const版本和getter的非常量版本中重复代码,请从非常量版本调用方法的const版本:static_cast(*this).Methodology();然而,由于过度使用VisualAssistXIntellisense导致意外使用,我输入了:const_cast(*this).Methodology();而且效果很好。在这种情况下,使用特定类型转换有什么不同?使用的IDE:VisualStudio2010。 最佳答案 假设this的类型是A*,没有区别。通常const_

C++ - 在没有 RTTI/dynamic_cast 的情况下向下转换菱形继承对象

我目前正致力于在非RTTI平台(Android)上集成使用大量RTTI内容的第三方包。基本上,我自己实现了RTTI,但遇到了一个问题。问题是很多类都有菱形继承问题,因为所有类都派生自同一个基类(对象)。所以,如果我想从基类向下转换为派生类,我必须使用dynamic_cast-但RTTI不可用!没有dynamic_cast的虚拟继承时,如何将对象从父对象转换为子对象?看起来是这样的:classA{public:virtualchar*func(){return"A";};};classB:publicvirtualA{public://virtualchar*func(){return"

C++ - 在没有 RTTI/dynamic_cast 的情况下向下转换菱形继承对象

我目前正致力于在非RTTI平台(Android)上集成使用大量RTTI内容的第三方包。基本上,我自己实现了RTTI,但遇到了一个问题。问题是很多类都有菱形继承问题,因为所有类都派生自同一个基类(对象)。所以,如果我想从基类向下转换为派生类,我必须使用dynamic_cast-但RTTI不可用!没有dynamic_cast的虚拟继承时,如何将对象从父对象转换为子对象?看起来是这样的:classA{public:virtualchar*func(){return"A";};};classB:publicvirtualA{public://virtualchar*func(){return"

c++ - reinterpret_cast 错误还是 UB?

这个问题在这里已经有了答案:Observingweirdbehaviorwith'auto'andstd::minmax(1个回答)structuredbindingswithstd::minmaxandrvalues(2个回答)关闭4年前。考虑以下代码:#include#includestd::uintptr_tminPointer(void*first,void*second){constautopair=std::minmax(reinterpret_cast(first),reinterpret_cast(second));returnpair.first;}以及由GCC8生成

c++ - reinterpret_cast 错误还是 UB?

这个问题在这里已经有了答案:Observingweirdbehaviorwith'auto'andstd::minmax(1个回答)structuredbindingswithstd::minmaxandrvalues(2个回答)关闭4年前。考虑以下代码:#include#includestd::uintptr_tminPointer(void*first,void*second){constautopair=std::minmax(reinterpret_cast(first),reinterpret_cast(second));returnpair.first;}以及由GCC8生成