传递对模板的引用
passing reference to the templates
本文关键字:引用 更新时间:2023-10-16
现在我正在模板上工作。所以,我被困在以下问题中,这是用随机值填充向量的代码,然后计算其中有多少个奇数值:
#include <iostream>
#include <vector>
#include <numeric>
#include <algorithm>
#include <iterator>
#include <ctime>
using namespace std;
class Odd{
private:
int c;
public:
bool operator()(int x){return x%2!=0;}
};
template<typename T,typename Q>
int count_(T f1,T f2,Q& check){
int count=0;
while(f1!=f2)
{
count+=check(*f1);
f1++;
}
return count;
}
int Rand(){
return ((rand()%100)+1);
}
int main(){
srand(time(0));
vector<int> V(100);
Odd O;
generate(V.begin(),V.end(),Rand);
cout<<count_(V.begin(),V.end(),O);
}
这工作得很好,但当我通过T&在参数中,它给出了error ..即
template<typename T,typename Q>
int count_(T& f1,T& f2,Q& check){
int count=0;
while(f1!=f2)
{
count+=check(*f1);
f1++;
}
我不知道为什么,因为这是对指针的引用,所以它会工作得很好…
正如AlchemicalApples在评论中指出的那样,V.begin()
和V.end()
返回右值,只能绑定到const
或右值引用。
实际上不需要通过引用传递迭代器——复制迭代器的成本很低。实际上,所有STL算法都是按值接受迭代器参数的。
实际上,你不应该通过引用传递迭代器,因为你的函数会修改它们,这是意料之外的(没有任何标准算法会这样做),如果你在代码中进一步使用这些迭代器,可能会导致错误。
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在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*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?