草庐IT

auto_cast

全部标签

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++ - `auto` 说明符的编译时间是否较慢?

从C++11开始,我们可以使用autoa=1+2而不是inta=1+2并且编译器推断出a的类型本身。它是如何工作的?在编译时(更多操作)是否比自己声明类型慢? 最佳答案 auto要求C++11编译器生成一些有限typeinference(查看Ocaml如果你想要一些更性感的类型推理语言)。但是开销只是编译时的。如果你替换autoa=1+2;与inta=1+2;(两者具有相同的含义,请参阅answerbysimplicis)并且如果您要求编译器optimize(甚至可能不要求优化)你可能会得到相同的machinecode.另见this

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”)。

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

若依报错class com.alibaba.fastjson2.JSONObject cannot be cast to class com.ruoyi......mode.LoginUser

若依框架开发的项目,登录之后访问系统监控–在线用户模块,系统报错,具体报错信息如下:classcom.alibaba.fastjson2.JSONObjectcannotbecasttoclasscom.ruoyi.common.core.domain.model.LoginUser(com.alibaba.fastjson2.JSONObjectandcom.ruoyi.common.core.domain.model.LoginUserareinunnamedmoduleofloaderorg.springframework.boot.devtools.restart.classloade

【C++】C++11——智能指针、内存泄漏、智能指针的使用和原理、RAII、auto_ptr、unique_ptr、shared_ptr、weak_ptr

文章目录C++117.智能指针7.1内存泄漏7.2智能指针的概念7.3智能指针的使用7.3.1auto_ptr7.3.2unique_ptr7.3.3shared_ptr7.3.4weak_ptrC++117.智能指针7.1内存泄漏  什么是内存泄漏:  内存泄漏指因为疏忽或错误造成程序未能释放已经不再使用的内存的情况。内存泄漏并不是指内存在物理上的消失,而是应用程序分配某段内存后,因为设计错误,失去了对该段内存的控制,因而造成了内存的浪费。  内存泄漏通常由于程序在设计上的缺陷或错误,例如动态分配内存后,未在合适的时间或无法正确释放该段内存,而导致的。内存泄漏通常需要程序员通过分析程序源代码