std:fund函数过载
Overload of std:find function
我试图重载std::find函数,方法是:
include <list>
include <string>
include "Marker.h"
namespace Test {
class MarkerContainer {
private:
std::list<Marker*> list;
double end_t;
inline bool exists(std::list<Marker*> *input_list, Marker* check);
public:
MarkerContainer();
MarkerContainer(double end_time);
bool addMarker(Marker* input);
double computeBeatTime(double sample_t);
double computeSampleTime(double beat_t);
void printAll();
};
}
std::list<Ableton::Marker*>::iterator std::find(std::list<Ableton::Marker*>::iterator first, std::list<Ableton::Marker*>::iterator last, Ableton::Marker* value){
for ( ;first!=last; first++) if ( **first==*value ) break;
return first;
}
但我发现了这个编译器错误:
"find"的越界定义与中的任何声明都不匹配/Users/中的命名空间"std"/MarkerContainer.h
我希望我犯了一些愚蠢的错误,我想做的很简单。。知道吗?
提前感谢!Pietro
不允许重载find
。您可以在std
命名空间中专门化模板,但在这种情况下,将find_if
与去引用函子一起使用要简单得多。
// Create DerefEquality comparison (I'll try to come back later and write it).
container_type::iterator iter = find_if(container.begin(), container.end(), DerefEquality(item_to_find));
不能像这样重载函数:需要在适当的命名空间中定义重载。您需要在全局范围内打开命名空间std
。特别是对于命名空间std
,我认为不允许您这样做。否则这会起作用。
也就是说,我认为你应该考虑使用std::find_if()
和一个合适的谓词,而不是使用你手工制作的方法:
auto it = std::find_if(list.begin(), list.end(),
[=](Abelton::Marker* el)->bool { return *el == *check; });
相关文章:
- "error: no matching function for call to"构造函数错误
- 什么时候调用组成单元对象的析构函数
- 继承函数的重载解析
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- C++模板来检查友元函数的存在
- 递归函数计算序列中的平方和(并输出过程)
- 对RValue对象调用的LValue ref限定成员函数
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 在C++STL中是否有Polyval(Matlab函数)等价物?
- 为什么使用 "this" 指针调用派生成员函数?
- 将对象数组的引用传递给函数
- 函数调用中参数的顺序重要吗
- 函数向量_指针有不同的原型,我可以构建一个吗
- 使用不带参数的函数访问结构元素
- 代码在main()中运行,但在函数中出现错误
- 内置函数可查看CPP中的成员变量
- 如何获取std::result_of函数的返回类型
- 如何在c++中为模板函数实例创建快捷方式
- std:fund函数过载