草庐IT

dynamic_pointer_cast

全部标签

c++ - 什么可能导致 dynamic_cast 崩溃?

我有一段代码看起来像这样:TAxis*axis=0;if(dynamic_cast(obj))axis=(dynamic_cast(obj))->GetXaxis();有时它会崩溃:Thread1(Thread-1208658240(LWP11400)):#00x0019e7a2in_dl_sysinfo_int80()from/lib/ld-linux.so.2#10x048c67fbin__waitpid_nocancel()from/lib/tls/libc.so.6#20x04870649indo_system()from/lib/tls/libc.so.6#30x048709

c# - “C++ void Pointer”和 “C# var”之间的区别

在学习C#时,我想到了这个问题。void和var有什么区别?这是我要分享的两个示例:void*voidInt=(void*)7;void*voidChar=(void*)'F';void*voidCharArray=(void*)"AbcString";这是var的示例:varvarInt=7;varvarChar='F';varvarCharArray="AbcString";void是匿名数据类型吗?如果是,那么主要是什么var和void之间的区别?有人可以帮我解决这种情况吗? 最佳答案 这里的其他答案还不错,但我认为它们并不清

c# - “C++ void Pointer”和 “C# var”之间的区别

在学习C#时,我想到了这个问题。void和var有什么区别?这是我要分享的两个示例:void*voidInt=(void*)7;void*voidChar=(void*)'F';void*voidCharArray=(void*)"AbcString";这是var的示例:varvarInt=7;varvarChar='F';varvarCharArray="AbcString";void是匿名数据类型吗?如果是,那么主要是什么var和void之间的区别?有人可以帮我解决这种情况吗? 最佳答案 这里的其他答案还不错,但我认为它们并不清

c++ - 我是否正确地说 const_cast 然后修改绑定(bind)到临时的 ref-to-const 可以吗?

我想检查一下我对此事的理解和结论。在IRC上,有人问:Isitacceptabletoconst_castaconstreferencethat'sboundtoatemporaryobject?翻译:他有一个ref-to-const绑定(bind)到一个临时的,他想抛弃它的const-ness来修改它。我的回答是我问过asimilarquestion以前,共识似乎是临时对象本身并不是天生的const,因此您可以摆脱对它们的引用的const特征,并且通过结果修改它们。而且,只要原来的ref-to-const仍然存在,就不会影响临时对象的生命周期。即:intmain(){constint

c++ - 我是否正确地说 const_cast 然后修改绑定(bind)到临时的 ref-to-const 可以吗?

我想检查一下我对此事的理解和结论。在IRC上,有人问:Isitacceptabletoconst_castaconstreferencethat'sboundtoatemporaryobject?翻译:他有一个ref-to-const绑定(bind)到一个临时的,他想抛弃它的const-ness来修改它。我的回答是我问过asimilarquestion以前,共识似乎是临时对象本身并不是天生的const,因此您可以摆脱对它们的引用的const特征,并且通过结果修改它们。而且,只要原来的ref-to-const仍然存在,就不会影响临时对象的生命周期。即:intmain(){constint

c++ - 为什么 back_insert_iterator/front_insert_iterator/insert_iterator 的 value_type/difference_type/pointer/reference 都是 void?

在我的项目中,我想将流拆分为一些给定类型的值,所以我实现了一个模板函数templateTOutputIterSplitSpace(std::istream&IS,TOutputIterresult){TElemelem;while(IS>>elem){*result=elem;++result;}returnresult;}我认为这很尴尬,因为我必须在调用时明确给出TElem的类型。例如,我必须写:std::vectorv;SplitSpace(std::cin,back_inserter(v));//IwanttoittobeSplitSpace(std::cin,back_inse

c++ - 为什么 back_insert_iterator/front_insert_iterator/insert_iterator 的 value_type/difference_type/pointer/reference 都是 void?

在我的项目中,我想将流拆分为一些给定类型的值,所以我实现了一个模板函数templateTOutputIterSplitSpace(std::istream&IS,TOutputIterresult){TElemelem;while(IS>>elem){*result=elem;++result;}returnresult;}我认为这很尴尬,因为我必须在调用时明确给出TElem的类型。例如,我必须写:std::vectorv;SplitSpace(std::cin,back_inserter(v));//IwanttoittobeSplitSpace(std::cin,back_inse

c++ - std::to_string、boost::to_string 和 boost::lexical_cast<std::string> 之间有什么区别?

boost::to_string的目的是什么?(在boost/exception/to_string.hpp中找到)以及它与boost::lexical_cast有何不同和std::to_string? 最佳答案 std::to_string,自C++11起可用,专门用于基本数字类型。它还有一个std::to_wstring变种。它旨在产生与sprintf相同的结果。会的。您可以选择这种形式来避免对外部库/头文件的依赖。抛出失败函数boost::lexical_cast和它不会throw的表亲boost::conversion::t

c++ - std::to_string、boost::to_string 和 boost::lexical_cast<std::string> 之间有什么区别?

boost::to_string的目的是什么?(在boost/exception/to_string.hpp中找到)以及它与boost::lexical_cast有何不同和std::to_string? 最佳答案 std::to_string,自C++11起可用,专门用于基本数字类型。它还有一个std::to_wstring变种。它旨在产生与sprintf相同的结果。会的。您可以选择这种形式来避免对外部库/头文件的依赖。抛出失败函数boost::lexical_cast和它不会throw的表亲boost::conversion::t

c++ - 如何避免 const cast 进行 map 访问?

我有以下问题:std::mapmap;voidgetColor(Aconst*obj){doubled=map[obj];//doesnotcompilewihtoutconst_cast(obj)//dosomething}我有一个mapstd::map(某处),它存储指向对象A的指针。我有一个getColor函数,它不操作对象A,因此将指向constA的指针作为输入.如果不使用const_cast,函数getColor将无法编译。constcast是一个设计问题,但如果我不想在map中制作键,我不知道如何规避它常量。任何帮助表示赞赏。 最佳答案