草庐IT

Implicit_cast

全部标签

c++ - boost::lexical_cast 和 double——奇怪的行为

为什么当我写"2.01"和"2.02"时,下面的代码会给我不同的结果?#include#include#includeintmain(){conststd::stringstr="2.02";try{constdoubleb=boost::lexical_cast(str)*100.0;std::cout(b);std::cout输出double:202int:202但是如果我将"2.02"更改为"2.01"它会给我以下输出:double:201badlexicalcast:sourcetypevaluecouldnotbeinterpretedastarget为什么?我正在使用Vis

c++ - 将 lexical_cast 字符串提升为两倍

我遇到了转换问题,希望得到您的帮助。我正在使用gcc4编译器,但我对gcc4的使用非常有限。我想将std::string转换为double。std::stringaQuantity=aRate.getQuantity();std::stringaAmount=aRate.getAmount();//aAmount="22.05"doubledQuantity=boost::lexical_cast(aQuantity);doubledAmount=boost::lexical_cast(aAmount);//dAmount=22.050000000000001顺便说一句,我也试过ato

c++ - reinterpret_cast 右值和优化

我正在将一堆代码转换为使用C++风格的转换(在-Wold-style-cast的帮助下)。我并不完全相信它对原始变量的使用,但总的来说我是C++风格转换的新手。一个问题发生在一些字节序转换代码中。当前代码如下所示:#defineREINTERPRET_VARIABLE(VAR,TYPE)(*((TYPE*)(&VAR)))//...uint16_treverse(uint16_tval){/*stufftoreverseuint16_t*/}int16_treverse(int16_tval){uint16_ttemp=reverse(REINTERPRET_VARIABLE(val,

c++ - dynamic_cast 返回 NULL 但它不应该

我有以下类层次结构:classIStorage{[...]}Q_DECLARE_INTERFACE(IStorage,"ch.gorrion.smssender.IStorage/1.0")classISQLiteStorage:publicIStorage{Q_INTERFACES(IStorage)[...]}Q_DECLARE_INTERFACE(ISQLiteStorage,"ch.gorrion.smssender.ISQLiteStorage/1.0")classDASQLiteStorage:publicQObject,publicISQLiteStorage{Q_OBJ

c++ - Casting - 为什么我应该为 Upcasting 做这件事

我一直在阅读该站点上的其他一些主题,他们提到了dynamic_cast和static_cast是如何安全地进行向上转换的。为什么向上转换甚至需要这些?例如,如果类B派生自A,则A*ptr=newB();仍然有效,并且表现得像A类型的对象。(我也来自Java背景,其中不需要进行向上转换的转换。我还在这个网站上读到,向下转换不需要dynamic_cast[有问题的“Whenshouldstatic_cast,dynamic_cast,const_castandreinterpret_castbeused?”].同样,我认为只有在向下转型时才真正需要转型,因为向上转型是自动发生的。我哪里错了

c++ - 避免 dynamic_cast 缓慢的著名解决方案?

我需要运行时多态性,所以我使用了dynamic_cast.但现在我有两个问题--dynamic_cast非常慢!(向下滚动基准。)长话短说,我最终以这种方式解决了问题,使用static_cast:structBase{virtual~Base(){}virtualinttype_id()const=0;templateT*as(){returnthis->type_id()==T::ID?static_cast(this):0;}templateTconst*as()const{returnthis->type_id()==T::ID?static_cast(this):0;}};st

c++ - 是否有理由在此代码中的字符串文字上使用 const_cast ?

我正在查看我即将开始使用的API的一些示例代码。以下模式让我有点困惑:char*str;str=const_cast("HelloWorld");printf("%s",str);(实际上有一个巨大的case语句,其中str被分配给每个case。)请注意printf采用constchar*。这种复杂的转换有什么合理的目的吗?这段代码的作者在其他地方应用了许多以性能为导向的技巧,但没有解释这里发生了什么。我的直觉是将此代码更改为:constchar*str;str="HelloWorld";printf("%s",str);我错过了什么吗? 最佳答案

c++ - 当 static_cast'ing 为仅移动类型时,Clang 与 GCC

考虑以下简单的仅移动类:structbar{constexprbar()=default;bar(barconst&)=delete;bar(bar&&)=default;bar&operator=(barconst&)=delete;bar&operator=(bar&&)=default;};现在,让我们创建一个包装器:templatestructbox{constexprbox(T&&x):_payload{std::move(x)}{}constexprexplicitoperatorT()&&{returnstd::move(_payload);}private:T_payl

c++ - 如何使用 numeric_cast 策略?

所以我有自己的uint64_t到uint32_t数字转换策略structMyOverflowHandlerPolicy{voidoperator()(boost::numeric::range_check_result){std::cout如何让boost::numeric_cast使用它? 最佳答案 为了使用numeric_cast,numeric_cast_traits特化应该在每个类型转换上定义。这些特化已经为内置数字类型定义了默认值。可以通过定义BOOST_NUMERIC_CONVERSION_RELAX_BUILT_IN_

c++ - 如何在没有 reinterpret_cast 的情况下使用 dlsym() 加载函数?

我正在尝试使用clang-tidy来执行C++核心指南。虽然它确实有很多有效点,但有一件事我无法真正解决:dlsym返回一个void*,我需要以某种方式将其转换为适当的函数指针。为此,我使用了reinterpret_cast。由于准则禁止这样做,因此我对此提出了警告。当然,我可以在任何地方放置//NOLINT注释,但我正在寻找一种不使用reinterpret_cast的解决方案,这样警告就会消失。这个问题有什么解决方法吗? 最佳答案 除了reinterpret_cast之外,该语言没有其他方法可以将函数指针类型转换为对象指针类型。这