草庐IT

my_numeric_cast

全部标签

c++ - C++ 中的 dynamic_cast 开销

我知道dynamic_cast有运行时检查,因此考虑更安全(可以在失败时返回空指针)但比static_cast慢。但是两者之间的开销有多糟糕?我真的应该考虑在循环中使用static_cast来解决常规大型项目中的性能问题吗?或者差异很小,只与特殊的实时程序有关。 最佳答案 你分析过它吗?规则是:当您知道目标类型有效时使用static_cast。当您不确定时使用dynamic_cast,并且您需要程序为您查找对象的运行时类型。就这么简单。所有其他考虑因素都是次要的。 关于c++-C++中的

c++ - 将静态库转换为共享库(从 libsome.a 创建 libsome.so): where's my symbols?

这个问题的标题是exactdupe,但该问题的答案对我没有帮助。我有一堆目标文件打包在一个静态库中:%g++-std=c++98-fpic-g-O1-c-ofoo.ofoo.cpp%g++-std=c++98-fpic-g-O1-c-obar.obar.cpp%ar-rclibsome.afoo.obar.o我想从libsome.a而不是目标文件生成libsome.so,但是这个库真的是准系统:%g++-std=c++98-fpic-g-O1-shared-olibsome.solibsome.a%nm-DClibsome.so0000xxxxA_DYNAMIC0000xxxxA_GL

c++ - 枚举的 reinterpret_cast 错误

为什么我不能对这样的转换使用reinterpret_cast运算符?enumFoo{bar,baz};voidfoo(Foo){}intmain(){//foo(0);//error:invalidconversionfrom'int'to'Foo'//foo(reinterpret_cast(0));//error:invalidcastfromtype'int'totype'Foo'foo(static_cast(0));foo((Foo)0);} 最佳答案 Ithinkthatreinterpret_castcanbeusef

c++ - static_cast 安全

AFAIK,对于指针/引用static_cast,如果此时编译器看不到类定义,则static_cast的行为将类似于reinterpret_cast。为什么static_cast对指针/引用不安全而对数值安全? 最佳答案 简而言之,因为多重继承。长:#includestructA{inta;};structB{intb;};structC:A,B{intc;};intmain(){Cc;std::cout(&c)(&c)输出:Cisat:0x22ccd0Bisat:0x22ccd4Aisat:0x22ccd0请注意,为了正确转换为B

c++ - 如何在 unsigned int 和 int 之间安全地进行 static_cast?

我有一个8字符的string表示一个十六进制数,我需要将它转换为一个int。此转换必须保留字符串"80000000"及更高版本的位模式,即这些数字应为负数。不幸的是,天真的解决方案:inthex_str_to_int(conststringhexStr){stringstreamstrm;strm>val;returnstatic_cast(val);}如果val>MAX_INT(返回值为0),则对我的编译器不起作用。将val的类型更改为int也会导致较大数字为0。我已经尝试了SO上各种答案的几种不同解决方案,但尚未成功。这是我所知道的:我在OpenVMS上使用HP的C++编译器(我相

c++ - 带有多个参数的 static_cast 是怎么回事?

谁能告诉我这个转换有什么效果(除了将happyNumber设置为1337),如果有的话,如果没有其他效果,我怎么能写这样的代码???这是编译器错误,还是C++的某些“隐藏特性”?inthappyNumber=static_cast(123.456,TRUE,"WTF",false,"IS",NULL,"GOING",0xff,"ON???",1337);我很惊讶这会编译。我是通过一个bug发现它的,在这个bug中我不小心将第二个参数设置为要进入正在转换的表达式的函数调用中的参数。这导致了一个讨厌的错误,其中对象是从第二个参数转换而来的,调用函数时只有一个参数。它编译了……而且最初并没有

c++ - const_cast<> 在 volatile 上的目的是什么?

我看到可以这样做,但我不明白其中的兴趣。 最佳答案 const和volatile听起来它们在变量上指的是相同的想法,但实际上并非如此。const变量不能被当前代码改变。volatile变量可能会被当前代码之外的某些外部实体更改。有可能有一个constvolatile变量——尤其是像内存映射寄存器这样的东西——在你的程序无法预测的时候被计算机改变,但你的代码不允许直接改变.您可以使用const_cast向变量添加或删除const或volatile(“cv-qualification”)。

ruby-on-rails - 如何在 localhost/<my_port> 上运行 Rails 3 应用程序?

要在Windows上运行Rails应用程序,我会这样做:cdrails服务器我看到以下内容:=>BootingWEBrick=>Rails3.0.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-Ctoshutdownserver[2011-01-1220:32:07]INFOWEBrick1.3.1[2011-01-1220:32:07]INFOruby1.9.2(2010-08-18)[i386-mingw32][2011-01-1220:32:07]INFOWEBric

java.lang.ClassCastException: java.util.LinkedHashMap cannot be cast to*****

原报错代码写法://获取table,强转成list集合ListlistNew=(List)message.getFormData().get("table");报错如下:java.lang.ClassCastException:java.util.LinkedHashMapcannotbecasttocom.*.通过调试,发现是LinkedHashMap类型,而不是实体类解决方法如下://获取table,转成list集合ObjectMappermapper=newObjectMapper();Listlist=(List)message.getFormData().get("table");L

c++ - RECT 和 POINT 数组之间的 reinterpret_cast 安全吗?

WindowsSDK包含一组typedef:typedeflongLONG;typedefstructtagPOINT{LONGx;LONGy;}POINT;typedefstructtagRECT{LONGleft;LONGtop;LONGright;LONGbottom;}RECT;然后,有一个WinAPI函数需要一个指向POINT结构数组的指针和该数组的长度:voidThatFunction(POINT*points,intnumberOfElements);我们有以下代码:RECTrect=...//obtainedfromsomewhereThatFunction(reint