草庐IT

static_casting

全部标签

c++ - 如何在 C++ 中使用 reinterpret_cast?

我知道C++中的reinterpret_cast可以这样使用:floata=0;intb=*reinterpret_cast(&a);但是为什么不能直接施法呢?floata=0;intb=reinterpret_cast(a);error:invalidcastfromtype'float'totype'int' 最佳答案 全部reinterpret_cast确实是允许您以不同的方式读取您传递的内存。你给它一个内存位置,并要求它读取该内存,就好像它是你要求它读的一样。这就是为什么它只能与指针和引用一起使用。我们以这段代码为例:#in

c++ - 如何在 C++ 中使用 reinterpret_cast?

我知道C++中的reinterpret_cast可以这样使用:floata=0;intb=*reinterpret_cast(&a);但是为什么不能直接施法呢?floata=0;intb=reinterpret_cast(a);error:invalidcastfromtype'float'totype'int' 最佳答案 全部reinterpret_cast确实是允许您以不同的方式读取您传递的内存。你给它一个内存位置,并要求它读取该内存,就好像它是你要求它读的一样。这就是为什么它只能与指针和引用一起使用。我们以这段代码为例:#in

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++ - 什么可能导致 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++ vector 问题 - 'LNK2001: unresolved external symbol private: static...'

在有人指责我不查看预先存在的问题之前,我已经查看并意识到它与声明有关,但我仍然无法让它工作(可能与我使用vector有关)。Manager.h:#include"Flight.h"#ifndefmanager_h#definemanager_hclassManager{staticvectorairports;staticvectorflights;public:staticvoidloadAirports();staticvoidloadFlights();staticAirportgetAirport(stringcode);staticvectorsplit(conststrin

C++ vector 问题 - 'LNK2001: unresolved external symbol private: static...'

在有人指责我不查看预先存在的问题之前,我已经查看并意识到它与声明有关,但我仍然无法让它工作(可能与我使用vector有关)。Manager.h:#include"Flight.h"#ifndefmanager_h#definemanager_hclassManager{staticvectorairports;staticvectorflights;public:staticvoidloadAirports();staticvoidloadFlights();staticAirportgetAirport(stringcode);staticvectorsplit(conststrin

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++ - 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