std:fund函数过载

Overload of std:find function

本文关键字:函数 fund std      更新时间:2023-10-16

我试图重载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; });