草庐IT

Overloaded

全部标签

c++ - 使用 std::function 时如何解决此 <unresolved overloaded function type> 错误?

在以下(有效的)代码示例中,模板化的register_enum()函数用于迭代枚举并调用用户提供的回调以将枚举值转换为C字符串。所有枚举都在一个类中定义,枚举到字符串的转换是使用静态to_cstring(enum)函数完成的。当一个类(如下面的着色器类)有多个枚举和相应的重载to_cstring(enum)函数时,编译器无法决定将哪个是正确的to_cstring()函数传递给register_enum()。我认为代码比我能解释得更好...#include#include//ActualcodeusesLua,butforsimplification//I'llhideitinthise

C++ 编译器错误 : ambiguous call to overloaded function

stringaux;intmaxy,auxx=0;cin>>aux;maxy=(int)sqrt(aux.size());我得到:1>errorC2668:'sqrt':ambiguouscalltooverloadedfunction1>couldbe'longdoublesqrt(longdouble)'1>or'floatsqrt(float)'1>or'doublesqrt(double)'为什么? 最佳答案 string::size()返回size_t,而sqrt在其任何版本中都不接受它。所以编译器必须强制转换,并且不能选

C++ 编译器错误 : ambiguous call to overloaded function

stringaux;intmaxy,auxx=0;cin>>aux;maxy=(int)sqrt(aux.size());我得到:1>errorC2668:'sqrt':ambiguouscalltooverloadedfunction1>couldbe'longdoublesqrt(longdouble)'1>or'floatsqrt(float)'1>or'doublesqrt(double)'为什么? 最佳答案 string::size()返回size_t,而sqrt在其任何版本中都不接受它。所以编译器必须强制转换,并且不能选

Java8 : ambiguity with lambdas and overloaded methods

我正在玩java8lambdas,但遇到了一个我没想到的编译器错误。假设我有一个功能interfaceA,abstractclassB和一个classC重载方法采用A或B作为参数:publicinterfaceA{voidinvoke(Stringarg);}publicabstractclassB{publicabstractvoidinvoke(Stringarg);}publicclassC{publicvoidapply(Ax){}publicBapply(Bx){returnx;}}然后我可以将lambda传递给c.apply并正确解析为c.apply(A).Cc=newC(

Java8 : ambiguity with lambdas and overloaded methods

我正在玩java8lambdas,但遇到了一个我没想到的编译器错误。假设我有一个功能interfaceA,abstractclassB和一个classC重载方法采用A或B作为参数:publicinterfaceA{voidinvoke(Stringarg);}publicabstractclassB{publicabstractvoidinvoke(Stringarg);}publicclassC{publicvoidapply(Ax){}publicBapply(Bx){returnx;}}然后我可以将lambda传递给c.apply并正确解析为c.apply(A).Cc=newC(

c++ - 'reinterpret_cast' : cannot convert from 'overloaded-function' to 'intptr_t' with boost. dll

我正在使用Boost.dll开发插件系统#include#include#includeclassbase{public:base(){};~base(){};templatestaticstd::shared_ptrcreate(){returnstd::make_shared();}virtualvoiddo1()=0;};classderived:publicbase{public:derived(){};~derived(){};virtualvoiddo1()override{}};BOOST_DLL_ALIAS(base::create,//();当我尝试在BOOST_DL

C++11 "overloaded lambda"带有可变参数模板和变量捕获

我正在研究一个可能被称为“重载lambda”的C++11习语:http://cpptruths.blogspot.com/2014/05/fun-with-lambdas-c14-style-part-2.htmlhttp://martinecker.com/martincodes/lambda-expression-overloading/使用可变参数模板重载n函数似乎对我很有吸引力,但事实证明它不适用于变量捕获:[&]中的任何一个|[=][y][&y](和[this]等,如果在成员函数中)导致编译失败:error:nomatchforcallto'(overload,main(in

c++ - 无法将参数 1 从 'overloaded-function' 转换为 '...'

现在我尝试使用boostbind&mem_fn。但是绑定(bind)重载函数有一个问题。后续代码编译报错如何解决?boost::functionbmf=std::mem_fun1(&IF_MAP::erase);boost::functionbmf=boost::mem_fn(&IF_MAP::erase);主要目的是编译后续代码IF_MAPM;boost::functionbmf=boost::bind(boost::mem_fn(&IF_MAP::erase),&M,_1);M.insert(IF_MAP::value_type(1,1.f));M.insert(IF_MAP::v

c++ - 接口(interface)设计: safety of overloaded function taking string and char array

假设我们有一个类可以写入输出内容classWriter{public:intwrite(conststd::string&str);intwrite(constchar*str,intlen);//...};我对这个、它的灵active以及所有这些都很好,直到我意识到char*buf=newchar[n];//notterminatedwith'\0'//loadupbufWriterw;w.write(buf);//compiles!那是一个真的讨厌的错误。我们可以通过一些模板进行一些修改classWriterV2{public:intwrite(conststd::string&s

我的类中的 c++ condition_variable wait_for 谓词,std::thread <unresolved overloaded function type> error

我想在我的类中使用一个线程,然后该线程需要使用一个condition_variable,条件变量将被阻塞,直到一个谓词被更改为true。代码如下所示:classmyThreadClass{boolbFlag;threadt;mutexmtx;condition_variablecv;boolmyPredicate(){returnbFlag;}intmyThreadFunction(intarg){while(true){unique_locklck(mtx);if(cv.wait_for(lck,std::chrono::milliseconds(3000),myPredicate)