草庐IT

overloading

全部标签

c++ - Curiously Recurring Template Pattern (CRTP) 是正确的解决方案吗?

场景考虑一个Logger类,它有一个为标准C++类型重载的成员函数write(),还有一些方便的函数模板,比如writeLine()内部调用write():classLogger{public:voidwrite(intx){...}voidwrite(doublex){...}...templatevoidwriteLine(Tx){write(x);...}...};进一步考虑一个子类FooLogger,它为特定于域的类型添加了额外的write()重载(我们称其中两个为FooType1和FooType2):classFooLogger:publicLogger{public:usi

c++ - 错误 : use of deleted function for overloaded template

我正在尝试模板特化,但无法确定为什么charconst*const无法在下面解析(尽管是有效类型)的原因。templateBfoo(A)=delete;templatevoidfoo(char*){}templatevoidfoo(charconst*const){}intmain(){{//typesOKcharconst*consta=nullptr;char*b=nullptr;}char*data;foo(data);//OKfoo(data);//ERRORreturn0;}错误error:useofdeletedfunction‘Bfoo(A)[withA=constcha

c++ - 如何消除重载模板函数的歧义?

以下代码有问题。虽然第1部分没问题,但问题出在main()的第2部分。编译时,会显示一条不明确的错误消息。如何更改代码以解决歧义?templatevoidfunc(Argarg){arg();}templatevoidfunc(Argarg,Args...args){func(args...);arg();}templatevoidfunc(Container&c){for(typenameContainer::reverse_iteratori=c.rbegin();i!=c.rend();++i){(*i)();}}voidf(){std::cout>v{f,f};func(v);

c++ - 链表 |重载 + 运算符 | C++

我正在训练我的C++,我正在尝试编写一个能够使用链表表示以下数字的库:999999999*([i=0]Σ[999999999]1000000000^i)例如,如果我的电话号码是711381450277869054011,它会这样表示:711*1000000000^2+381450277*1000000000^1+869054011>*1000000000^0所以,这是我的LL的结构及其功能:typedefstructnode*ll;structnode{unsignedintdata;llnext;};boolinsert(ll&,unsignedint);//...voidcopy(

c++ - 指针深拷贝的 vector

我是一个非常新的程序员,也是一个super初学者,所以我对C++了解不多。我有一个关于制作指针的深层拷贝的问题。我拥有的是一个充满POD的A类和一个指向此类的指针(A*P)。我有第二个B类,其中包含一些其他POD和指向A类的指针vector。我想用A*P的深层拷贝填充这个vector,因为在一个循环中我将动态分配和释放它。以下不起作用。我相信它是我的复制构造函数和=运算符的重载。这是我为了乐趣和学习而做的事情。classA{public:...............};classB{public:B();~B();B(constB&Copier);B&B::operator=(con

c++ - 具有 C++ 重载函数的 SWIG 类型映射

我有一个这样的函数定义:voidFoo(intszData,intData[]);我有一个像这样的SWIG类型映射:%typemap(in)(intszData,intData[]){inti;if(!PyTuple_Check($input)){PyErr_SetString(PyExc_TypeError,"Expectingatupleforthisparameter");$1=0;}else$1=PyTuple_Size($input);$2=(int*)malloc(($1+1)*sizeof(int));for(i=0;i类型映射允许我像这样从Python调用Foo():富

c++ - C++中未定义数量的参数

这个问题在这里已经有了答案:VariablenumberofargumentsinC++?(17个答案)关闭9年前。我能否像JavaScript一样重载我的函数以使用大量参数执行某些操作。例如:functionf(){alert(arguments[0]);}f(4);//willalert4我可以在C++中做同样的事情吗?

c++ - 错误 : no instance of overloaded function "std::make_shared" matches the argument list

查看ApreviousstackQuestionstd:make_sharedvsstd::shared_ptr,我试图在一个uni项目中实现它。这是之前的“问题”:Ican'tthinkofanysituationwherestd::shared_ptrobj(newObject("foo",1));wouldbepreferredtoautoobj=std::make_shared("foo",1);因此我采用了这段代码:std::shared_ptrpT1(newTriangle(pCanvas,30,30,30,60,60,30,255,0,0));并将其修改为这段代码:aut

c++ - "unresolved overloaded function type"在 std::function 中有静态函数

尝试将重载静态函数传递给std::function时出现“未解析的重载函数类型”错误。我知道类似的问题,例如this和this.然而,即使那里的答案可以将正确函数的地址放入函数指针中,它们也会因std::function而失败。这是我的MWE:#include#include#includestructClassA{staticstd::stringDoCompress(conststd::string&s){returns;}staticstd::stringDoCompress(constchar*c,size_ts){returnstd::string(c,s);}};voidh

c++ - 传参积分提升

为什么编译器不能将char提升为int&但在通过引用传递给常量时没有问题(char到intconst&)?示例代码:#includeusingnamespacestd;voidfunc1(int&i){cout 最佳答案 这是允许的:charc='X';constint&i=c;我们正在隐式地将c提升为int并将i绑定(bind)到该临时值。这不会真正导致任何令人困惑的行为。i与c具有相同的值,只是类型不同。但是,如果使用non-const允许相同的逻辑会发生什么:charc='X';int&i=c;i='J';i不能直接绑定(bi