Nik*_*ann 21 c++ parameters pass-by-reference eigen eigen3
当不需要编写模板函数时,Eigen引入了Ref <>类来编写具有Eigen对象作为参数的函数,而不使用不必要的临时对象.人们可以在这里读到这一点.
当进一步搜索互联网时,我使用Ref <>类找到了几个不同的参数声明.在Eigen文档中,它们const Eigen::Ref<const Eigen::MatrixXf>&用于第一个示例中的只读参数.在第二个例子Eigen::Ref<Eigen::MatrixXd>中引入了读写参数,这里BUT const Eigen::Ref<const Eigen::MatrixXd>用于只读参数(无引用).所以我的问题是:
以下声明和我何时使用它有什么区别?`
const Eigen::Ref<const Eigen::MatrixXd>&const Eigen::Ref<const Eigen::MatrixXd>const Eigen::Ref<Eigen::MatrixXd>&const Eigen::Ref<Eigen::MatrixXd>Eigen::Ref<const Eigen::MatrixXd>&Eigen::Ref<const Eigen::MatrixXd>Eigen::Ref<Eigen::MatrixXd>&Eigen::Ref<Eigen::MatrixXd>为了完整性,我列出了const使用和参考的每种可能组合.
gga*_*ael 21
一般来说,使用非const引用Ref<T>&并不是一个好主意,因为这只有在调用者Ref<T>手头有一个对象时才有效.这丢弃5和7.
案例3和案例4没有意义,一般不会编译.
然后,a const Ref<const T>和a 之间没有太大区别,const Ref<const T>&因为用现有Ref<const T>对象调用函数的可能性不大,因此Ref<const T>无论如何都必须在大多数情况下创建函数.尽管如此,我们仍然可以推荐超过2或6的1.
总而言之,我们可以推荐Ref<T>一个可写引用,以及const Ref<const T>&一个const引用.
Ref<const T>如果要通过Ref使用placement new调用构造函数来更改引用的矩阵(而不是其内容),则选项6 可能仍然很有趣.
| 归档时间: |
|
| 查看次数: |
4478 次 |
| 最近记录: |