草庐IT

assignment-operator

全部标签

c++ - 为什么这个用于检测类型 T 是否具有 void operator(EDT const&) 的 C++ 特性会失败?

我正在尝试使用SFINAE来检测作为模板参数T传递的类型是否具有T::operator()(Pconst&),其中P也是模板参数。我在MemberDetectorIdiom的这个例子之后为我的解决方案建模不幸的是,我无法让它为operator()工作,即使我可以让它为普通方法工作。下面是一些演示我面临的问题的示例代码:#include#include#include#includeusingnamespacestd;structhas{voidoperator()(intconst&);};structhasNot1{voidoperator()(int);};structhasNot

c++ - 在c++中为什么我们可以重载 `operator ->`而不能重载 `operator .`

这个问题在这里已经有了答案:Whycan'tyouoverloadthe'.'operatorinC++?(4个答案)关闭5年前。在c++中,为什么我们可以重载operator->而不能重载operator.?同样,为什么我们可以重载operator->*而不能重载operator.*呢?如果你能帮助我,我将不胜感激!

c++ - VC 选择错误的 operator<< 仅在第一次调用时重载。漏洞?

我花了一些时间删除所有无影响的代码,这就是我的问题。---File.h---#include#includetemplateclassDataOutput:publicstd::basic_ofstream{public:DataOutput(conststd::string&strPath,boolbAppend,boolbBinary):std::basic_ofstream(strPath.c_str(),(bAppend?ios_base::app:(ios_base::out|ios_base::trunc))|(bBinary?ios_base::binary:0)){if

c++ - 运算符重载 "operator T * ()"产生比较运算符?

classTest{public:operatorTest*(){returnNULL;};};intmain(){Testtest;if(test==NULL)printf("Wtfhappenedhere?\n");return0;}这段代码如何编译?Test是如何获得比较运算符的?是否有一些隐式转换?重载运算符甚至意味着什么(和做什么)? 最佳答案 重载运算符添加了从Test到Test*的转换。由于没有定义将Test和NULL作为参数的比较运算符,因此会尝试任何存在的转换运算符。operatorTest*返回一个与NULL相当

c++ - 指针和数组上 operator[] 的索引参数类型

指针上运算符[]的自然参数类型是什么,如:structfoo{value_toperator[](i){returndata[i];}value_t*data;};我知道我可以输入任何整数类型,但是数组索引的自然类型是什么,即。哪个不会导致隐式转换? 最佳答案 指针上的operator[]可以是任何整数表达式总的来说,ptrdiff_t在技术上是你想要的,如果data和data+i是任意两个任意指针中的任意一个,并且指向任意内存块,因为ptrdiff_t被定义为用于保存差异的有符号类型两个指针之间(但是,不能保证不会溢出:ptrdi

c++ - 实现Matlab的冒号: operator in C++ expression templates class

我正在实现一个C++表达式模板库。我已经设置了一个适当的SubMatrixExpr类来收集矩阵中的元素,启用类似的语法B=SubMatrix(A,1,3,2,10);相当于Matlab的B=A(1:3,2:10);当然,Matlab的语法比我的要舒服得多。所以我的问题是有没有可能在C++中设置Matlab的冒号:运算符?非常感谢您。 最佳答案 简短的回答:没有。冒号不是有效的C++运算符,因此不能重载。即使可以,它仍然不可能轻松实现您的需求,因为它肯定会优先于逗号运算符,这将使您的表达式位于A((1:3),(2:10))行中。,如果

c++ - operator= 的返回类型 - 引用还是值?

从函数“operator=”返回有什么区别byreferencebyvalue?在下面的示例中,这两个版本似乎都产生了正确的结果。#includeusingnamespacestd;classCComplexNumber{floatm_realPart;floatm_imagPart;public:CComplexNumber(floatr,floati):m_realPart(r),m_imagPart(i){}//thefollowingcanbealso//CComplexNumber&operator=(constCComplexNumber&orig){CComplexNum

c++ - 如何将具有 "deleted"复制构造函数和赋值运算符的类放入映射中?

因为我使用的是一个不完全是C++11的编译器(VS11),所以我收到一个关于防止使用复制构造函数和赋值运算符的链接器错误。一切都很好,但问题是我不能将我的类放在std::map中,其中键是uin32_t,值是我的类。我什至尝试了emplace,但它不起作用。我正在考虑std::move将unique_ptr放入map中,但不想重新设计容器。那么有没有什么优雅的方法可以做到这一点(优雅==不像在map中放置一个虚拟对象然后在值内存中放置新的:)?代码位是这样的:std::mapm_map;//declarednotdefinedpublic:LogFileWriter(constLogF

c++ - 为类存储指向另一个类的指针复制构造函数析构函数和赋值运算符

我是新来的,这是我的第一个问题。我对我的家庭作业有疑问。我被要求设计一个抽象类“Base”,它由类“Sub”继承(在作业中有sub1、sub2等,但我试图尽可能地缩小它的范围)。然后,我应该设计一个类“BasePtr”,它存储一个指向“Base”对象的指针。最后,baseptr:s将存储在std::vector中,并使用ostream_iterator和复制写入文件。然后应使用ifstream_iterator读取该文件,并将其存储在std::list中。我已经解决了上述问题,但在实现析构函数、复制构造函数和赋值运算符时遇到了一些问题(因为我在我的BasePtr类中动态分配内存,我相信

k3s x GitLab Runner Operator,GitLab CI 云原生构建新体验

GitLabCI是非常常用的一款CI/CD工具,只需要在.gitlab-ci.yml 文件中用YAML语法编写CI/CD流水线即可。而GitLabCI能够运行的关键组件是GitLabRunner。GitLabRunner是一个轻量级、高扩展的代理,主要用来执行GitLabCI/CD流水线中的Job,然后将Job的执行结果返回GitLab实例。GitLabRunner的安装方式有很多种,包括安装包、Docker、HelmChart等,本文将用GitLabRunnerOperator的方式来在k3s上安装GitLabRunner,并执行CI/CD流水线。关于其他安装方式的详情,可以查看 GitLa