在模板类中通过引用传递
Pass by reference within template class
本文关键字:引用 更新时间:2023-10-16
我的基类中有一个成员函数,它通过引用接受参数:
// Base
template<class Data, class Variable_Type = double>
class Parallel_Data
{
...
void FuncA(Data& data, int& Global_ID)
{Data_Local.push_back(data); Local_To_Global_ID.push_back(Global_ID);};
}
// Derived
class Derived: public Parallel_Data<Atom_Placed>
问题是当我尝试在派生成员函数中调用该函数时
Push_Back_This_CPU(Atom_Placed(Position_Atom), Global_ID);
我收到以下错误
no known conversion for argument 1 from ‘Atom_Placed’ to ‘Atom_Placed&’
我只是想通过引用传递参数,不知道它为什么要转换?
像
Atom_Placed(Position_Atom)
这样的临时不能绑定到非常量引用,例如参数Atom_Place&
。原因是它们是临时物体,现在随时都会死去。
您可以创建一个类型为 Atom_Placed
的局部变量,并将其传递给函数Push_Back_This_CPU
Atom_Placed tmp(Position_Atom);
Push_Back_This_CPU(tmp, Global_ID);
不能将临时值绑定到非常量左值引用。但是,由于您的函数不需要修改其参数,最简单的解决方案是采用const
引用:
void FuncA(Data const & data, int const & Global_ID)
// ^^^^^ ^^^^^
现在,您可以将临时值传递给函数。
(注意:我假设Data_Local
和Local_To_Global_ID
具有标准的容器接口。如果他们的push_back
函数也接受非常量引用,那么它们也需要修复。
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?