草庐IT

c++ - 为什么 `const type& variable` 作为函数输入?

我正在将一些函数从Matlab转换为C++,其中有一些与矩阵有关。我在Internet的某处找到了这个简单的函数:typedefstd::vector>Matrix;Matrixsum(constMatrix&a,constMatrix&b){size_tnrows=a.size();size_tncols=a[0].size();Matrixc(nrows,std::vector(ncols));for(inti=0;i谁能解释一下为什么他们使用constMatrix&a而不是Matrixa作为输入?他们是否习惯使用它,或者使用它有什么好处,因为我没有看到2个版本(constMatr

c++ - 如何解决模板参数推导中的 const/non-const 冲突

我有一个接受std::pair的函数模板以及其中一种类型的值。我想使用来自std::map的条目调用此函数作为对参数。#include#includetemplatevoiddo_stuff(std::pairconst&pair,T1const&val){//Imaginethatthisdoessomethingimportant...}intmain(){std::mapfoo{{0,0.0}};do_stuff(*foo.begin(),0);}编译失败,因为map条目的类型是std::pair,所以T1的类型推导有冲突的类型:constint通过pair参数,和int通过va

c++ - const 左值引用和右值引用之间的重载解析

#include#includevoidfnc(conststd::string&){std::cout所有编译器都选择std::string&&版本的fnc,这是合乎逻辑的,因为创建了临时的std::string用于引用绑定(bind),但我找不到它在C++14标准中的描述。我在那里找到了一段(3.2):—StandardconversionsequenceS1isabetterconversionsequencethanstandardconversionsequenceS2if[...]—S1andS2arereferencebindings(8.5.3)andneitherre

c++ - 防止为非常量对象调用 const 函数

以下代码包含operator()的常量和非常量版本.ItoutputsNon-constop,falseConstop,trueConstop,trueConstop,true即如果类型为S的对象之一,则调用const版本是const或者如果提交的指针是const-行//2,//3,//4.现在我想要//2行的代码导致编译时错误,即我希望const版本只能在const对象上调用。显然是一个static_assert在is_const_v不管用。还有其他想法吗?我知道,将非常量变量转换为常量变量很容易。但这至少会使误用变得明显。#include#includestructS{voidop

c++ - 仅在与类的其他对象进行比较时,是否有任何理由不将 operator== 作为成员重载?

我一直在互联网上寻找答案,但我找不到任何答案。给出的唯一原因似乎与比较不同类型的对象有关(例如MyClass==int)。但最常见的用例是将一个类实例与同一类的另一个实例进行比较,而不是与任何不相关的类型进行比较。换句话说,我确实理解以下方面的问题:structA{booloperator==(intb);};但是我找不到任何好的理由在最明显的用例中不使用成员函数:structA{booloperator==(constA&);};最规范的重复Whatarethebasicrulesandidiomsforoperatoroverloading?作为经验法则说“将二元运算符重载为非成员

c++ - 声明的循环依赖

我正在尝试实现访问者模式的示例,但我在类声明的循环依赖方面遇到了麻烦。当我做访问者类的前向声明时,俄罗斯和英格兰类不知道访问者有访问方法,但是当我扩展访问者的方法接受的前向声明时,我需要使用英格兰和俄罗斯类,但他们需要知道谁访问者是,因为他们在代码中使用了这种类型。我尝试了多种排序代码的变体,但我完全失败了。请帮我理解,C++需要什么才能得到这个。谢谢。#include#includeusingnamespacestd;classVisitor;classLand{public:virtualvoidaccept(constVisitor*v);};classEngland:publi

c++ - 从 "foo<T>"转换为 "const foo<const T>"- C++

我有一个类似的函数(请不要关心通过引用返回临时值。这只是一个解释问题的例子),constfoo&get_const(){foof;returnf;}这显然无法编译。我正在寻找一种方法来确保调用者不会更改T的foo.我怎样才能确保这一点?我已经看到boost::shared_ptr的类似行为.shared_ptr可转换为constshared_ptr.我不知道它是怎么做到的。任何帮助都会很棒。 最佳答案 编译器看到foo和foo作为两种完全不同且不相关的类型,所以foo与任何其他转换一样,类需要明确支持这一点。如果您可以控制foo类,

c++ - 如何定义 "Do-Nothing"排序?

我正在开发一个系统,在该系统中,我需要能够按给定谓词对vector进行排序,而我的类不应该控制该谓词。基本上,我向他们传递一个派生类,然后他们盲目地对其进行排序。作为“令人愉快的怪癖”之一,排序模式之一是条目顺序。这是我到目前为止所得到的。structStrategy{virtualbooloperator()(constLoan&lhs,constLoan&rhs)const=0;};structstrategyA:publicStrategy{booloperator()(constLoan&lhs,constLoan&rhs)const{returntrue;}};structs

c++ - 在 C++ 中返回一个 float 组

我目前在C++中有一个4x4矩阵类,我将每个值存储为float:Matrix4d::Matrix4d(constfloat&m00,constfloat&m01,constfloat&m02,constfloat&m03,constfloat&m10,constfloat&m11,constfloat&m12,constfloat&m13,constfloat&m20,constfloat&m21,constfloat&m22,constfloat&m23,constfloat&m30,constfloat&m31,constfloat&m32,constfloat&m33){_m00

c++ - 在初始化列表中调用私有(private)函数的情况下,它是未定义的行为吗?

考虑以下代码:structCalc{Calc(constArg1&arg1,constArg2&arg2,/**/constArgN&argn):arg1(arg1),arg2(arg2),/**/argn(argn),coef1(get_coef1()),coef2(get_coef2()){}intCalc1();intCalc2();intCalc3();private:constArg1&arg1;constArg2&arg2;//...constArgN&argn;constintcoef1;//Iwanttouseconstbecauseconstintcoef2;//no