草庐IT

Implicit_cast

全部标签

c++ - 为什么 implicit == on map<<int,MyClass> 不编译?

我在为我的一个类(class)定义==时遇到了一个奇怪的问题。我将此处的代码简化为我在visual2013上测试过的示例;MyClass在命名空间N中定义这确实编译:N::MyClassa,b;booltest=a==b;这也是:constN::MyClassa,b;booltest=a==b;这不编译std::mapa,b;booltest=a==b;供您引用,=​​=运算符声明如下:booloperator==(constN::MyClass&a,constN::MyClass&b);这是我得到的错误:errorC2678:binary'==':nooperatorfoundwhi

c++ - 使用 boost::lexical_cast 将 UUID 转换为字符串时出现 Boost 编译错误

我有这段代码是基于SO中的几篇文章:boost::uuids::uuiduuid=boost::uuids::random_generator()();autouuidString=boost::lexical_cast(uuid);但是当我编译这段代码时,我得到了这个错误:Sourcetypeisneitherstd::ostream`ablenorstd::wostream`ableC:\Local\boost\boost\lexical_cast\detail\converter_lexical.hpp我该如何修复这个错误? 最佳答案

c++ - 为什么此 reinterpret_cast 在 Visual Studio 中失败?

我有一些代码(见下文),奇怪的是,当我通过gcc运行代码时它编译得很好,但是当我在VisualStudio2017中打开相同的文件时,我得到一个编译器错误,如下所示:ErrorC2440'reinterpret_cast':cannotconvertfrom'::size_t'to'Alias'这是一个最小的示例,如果您愿意,可以尝试一下。只需点击“新建项目”,然后选择C++Windows控制台应用程序,插入这段代码,并尝试在默认的x86Debug模式下编译:#include"stdafx.h"#includetypedefstd::size_tAlias;AliasmakeAlias

c++ - const_cast 和 UB

$5.2.11/7-"[Note:Dependingonthetypeoftheobject,awriteoperationthroughthepointer,lvalueorpointertodatamemberresultingfromaconst_castthatcastsawayaconst-qualifier68)mayproduceundefinedbehavior(7.1.5.1).]"这部分(C++03)的措辞让我感到惊讶。令人惊讶的是两件事。a)首先,“可能”的使用。为什么是“可以”?标准中的其他地方对未定义的行为非常明确b)为什么不是直接抛弃“未定义行为”的原始co

c++ - 是否可以使用 static_cast 避免 vtable 开销?

这是我的问题。我有一个基类和一个派生类,它覆盖了基类中的一些方法。为简单起见,请考虑以下示例:structbase{virtualvoidfn(){/*basedefinitionhere*/}};structderived:base{voidfn(){/*deriveddefinitionhere*/}};在我的实际程序中,这些类作为参数传递给其他类并在其他方法中调用,但为了简单起见,让我们创建一个简单的函数,将基类或派生类作为参数。我可以简单地写voidcall_fn(base&obj){obj.fn();}并且由于虚函数的缘故,对适当函数的调用将在运行时解析。但是,我担心如果ca

c++ - 如何将 "cast"一个双参数函数转换为一个参数函数?

在matlab中,可以这样写:S=@(x,y)x^2+y^2-1G=@(x)S(x,1);如果我有一个需要单参数函数的函数,我可以执行上述操作。我如何在c/c++中执行此操作?我有一个库函数(来自CGAL库),它期望一个本身只有一个参数的函数作为参数。理想情况下,我有一个类(SphericalHarmonics),我希望有一个接受一个参数的成员函数。所以我有:FTSphericalHarmonics::distFunction(Point_3p)(注意FT是一个类似于double的类型)但是当然当我尝试SphericalHarmonics*sh=newSphericalHarmonic

c++ chrono duration_cast 到毫秒结果以秒为单位

我想要自纪元以来的毫秒数。一个流行的解决方案如下所示(这里提出的这个问题的解决方案之一Gettimesinceepochinmilliseconds,preferablyusingC++11chrono)#include#includeintmain(){automillitime=std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count();std::cout通过调用g++来编译它,比如g++-std=c++11main.cpp-otimetest产生输出13726860

已解决java.lang.ClassCastException: class java.lang.Integer cannot be cast to class java.lang.String异常的

已解决java.lang.ClassCastException:classjava.lang.Integercannotbecasttoclassjava.lang.String异常的正确解决方法,亲测有效!!!文章目录报错问题解决思路解决方法交流报错问题java.lang.ClassCastException:classjava.lang.Integercannotbecasttoclassjava.lang.String解决思路java.lang.ClassCastException:classjava.lang.Integercannotbecasttoclassjava.lang.St

c++ - 如何使用 reinterpret_cast 转换为 C++ 中的派生类指针

这是我的测试示例:structbase{virtual~base(){}intx;};structderived:publicvirtualbase{base*clone(){returnnewderived;}derived():s("a"){}std::strings;};intmain(){derivedd;base*b=d.clone();derived*t=reinterpret_cast(b);std::couts它在我打印s的那一行崩溃了。由于“b”是指向派生类的指针,因此reinterpret_cast应该可以正常工作。我想知道为什么它会崩溃。同时,如果我用dynami

c++ - 是否可以使用 dynamic_cast 进行模板类型检查?

templatevoidcheckObject(TgenericObject){MyClassA*a=dynamic_cast(genericObject);if(a!=NULL){//weknowitisoftypeMyClassA}MyClassB*b=dynamic_cast(genericObject);if(b!=NULL){//weknowitisoftypeMyClassB}}这样的事情可能吗?我们有一个模板类型,但我们想知道它是实际类型吗? 最佳答案 在模板世界中,您可能只想为每种类型专门化模板,而不是进行运行时检查