草庐IT

c++需要将int类型转换为unsigned int

我将此代码作为C++项目的一部分unsignedintfn(){//dosomecomputationsintvalue=....if(value我不需要在最后一个return语句中使用强制转换,因为所有负数都将在if语句中被捕获(因此返回0)。此外,此函数fn是从另一个函数(其返回类型为int)调用的,该函数仅返回fn返回的值。谢谢.. 最佳答案 目的是消除可能发出的编译器警告。 关于c++需要将int类型转换为unsignedint,我们在StackOverflow上找到一个类似的问

c++ - 如何将整数转换为 std::u16string (C++11)?

没有方法std::to_u16string(...)。显然static_cast似乎不是进行此类转换的最合适方法。对于相反的转换,从string到int,可以使用函数std::stoi()定义转换器,但是从int到u16string它不工作。我尝试了以下方法:inti=1234;std::u16strings;std::wstring_convert,char16_t>convert;s=convert.from_bytes(std::to_string(i));std::cout我也试过这样做:typedefstd::basic_stringstreamu16ss;u16ssss;s

c++ - 如何从父类转换为子类的接口(interface)

假设我有一个父类Parent和子类Child1和Child2,后者实现了MyInterface:classParent{public:Parent();virtual~Parent();virtualvoidMyMethod();}classMyInterface{public:virtual~MyInterface(){}virtualvoidMyInterfaceMethod()=0;}classChild1:publicParent{public:Child1();virtual~Child1();}classChild2:publicParent,MyInterface{pub

c++ - 将整数类型转换为枚举 : functional cast vs initialization

假设有一个这样的枚举:enumfoo:int{first,second}然后我使用它如下:foof(1);//error:cannotinitializeavariableoftype'foo'withanrvalueoftype'int'foof=foo(1);//OK!我想知道这两者有什么区别?我知道第二个版本可以看作是函数式转换,但为什么这会有什么不同?例如,如果我这样做:classBar{};Barb=Bar(1);//nomatchingconversionforfunctional-stylecastfrom'int'to'Bar'我显然得到了一个有意义的错误。因此,这让我

c++ - clang 编译的程序在 std::any_cast 期间抛出 std::bad_any_cast

我正在开发一个使用std::any的应用程序.最近我发现,当我用clang编译它时,我得到了bad_any_caststd::any_cast之一的异常我确定我正在转换为正确的类型。我添加了一些typeid(T).name()的转储至cout确保插入std::any的类型没有区别并输入我正在尝试转换到的内容。我试图编写简单的程序来演示它,但我无法重现它。值得一提的是:我正在传递一包std::any(每个内部包含不同的类型)并且只有一个有问题(它是std::map)。当我切换到boost::any时问题消失了(或者如果我使用gcc构建我的应用程序)。我已经深入了解std::any_cas

c++ - gcc 与 clang : noexcept parsed in unused template specialization when static casting

我正在尝试将函数指针静态转换为特定函数重载,但似乎clang仍会解析(未使用的)模板特化的noexcept语句,从而生成编译器错误。如果未使用相应的函数重载,GCC似乎并不关心noexcept。templatevoidfun(T)noexcept(T(1)){}voidfun(int){}voidfun(int*){}intmain(){inta;fun(&a);//callingworksfinefun(a);static_cast(&fun);//staticcastingdoesn't}https://godbolt.org/z/ixpl3f这里是哪个编译器出错了?当将函数指针转

c++ - 当有符号/无符号不匹配时会发生什么转换?

当编译器发现有符号/无符号不匹配时,它会采取什么措施?有符号数是否转换为无符号数,反之亦然?为什么? 最佳答案 如果操作数是整数且有一个无符号值,则转换为无符号。例如:-1>(unsignedint)1//as-1willbeconvertedto2^nbits-1转换int->unsignedint为:n>=0->n;nn(mod2^nbits),例如-1变为2^nbits-1转换unsignedint->int是:nn;n>INT_MAX->实现定义Ifthedestinationtypeisunsigned,theresult

c++ - 动态转换如何工作?

假设我有类型A和派生类型B。当我执行从A*到B*的动态转换时,环境会执行哪种“运行时检查”?它如何知道转换是合法的?我假设在.Net中可以在对象的header中使用附加的元数据,但在C++中会发生什么情况? 最佳答案 精确算法是特定于编译器的。这是它根据ItaniumC++ABI工作的方式(2.9.7)标准(在GCC之后编写并遵循)。指向基类的指针是指向“大”类主体中间的指针。“大”类的主体以这样一种方式组装,无论您的指针指向什么基类,您都可以统一访问该“大”类的RTTI,实际上您的“基”类是。这个RTTI是一个与“大”类信息相关的

c++ - 将指针转换为 int/将指针存储为类型 T

我希望计算一个指针被使用了多少次。我有一张map:staticstd::mapcounters;当我想向它插入一个新值时,我会像这样使用它:templateMyClass::addPointer(T*tPtr){counters[((unsignedint)tPtr)]++;}做这样的类型转换可以安全吗?这不是一项昂贵的手术等吗?另外,这是确保每个指针只得到一个计数的合适方法吗?谢谢 最佳答案 IMO,您真的不需要将其转换为unsignedint。您可以使用void*获取map:staticstd::mapcounters;空检查在

c++ - reinterpret_cast<int*>(char*) 与 static_cast<int*>(static_cast<void*>(char*)) - 使用哪个?

当你动态分配了一个char*类型的缓冲区并想将它转换为特定类型时,你是否应该使用类似的东西reinterpret_cast(char*)或者类似的东西static_cast(static_cast(char*))为什么?我个人很想使用后者,因为对我来说,它并不是真正的数据“重新解释”(而只是一种分配缓冲区的机械方式)而且它看起来不像是一个来源错误的方式可能与典型的reinterpret_cast相同,但这是正确的直觉吗? 最佳答案 AccordingtoDaveAbrahams,使用链式static_casts是强制指针类型的正确、