C ++ 11没有用于调用'std :: vector的匹配函数

时间:2016-12-15 12:25:55

标签: c++ c++11 vector std

我有一个结构msg

struct msg {
    //destination port
    int addr;
    //data
    unsigned long long payload;

    //prioritized flag
    bool isPrio;

    //construcor?
    msg(int a, int p, bool b) : addr(a), payload(p),isPrio(b) { }

    msg() : addr(0), payload(0), isPrio(false) { }

    ...
};

通过SystemC distributor接收msg并将某些元素推送到二维向量sc_in的课程std::vector<std::vector <msg>> buffer

class distributor: public sc_module {
    public:
        sc_vector<sc_in<msg>> inputMsg;
        std::vector<std::vector <msg>> buffer;
        int n, m, bufferSize;
        ...


        distributor(sc_module_name name, int n, int m, int bufferSize) : //n -> number of inputs, m -> number of outputs
            sc_module(name),
            inputMsg("inputMsg", n),
            n(n),
            m(m),
            buffer(m),
            bufferSize(bufferSize)
            ...
        {
            SC_HAS_PROCESS(distributor);
            SC_METHOD(receive); sensitive << ...;
            ...
        }

        void receive() {
            for(int i = 0; i < n; i++){
                msg newMessage = inputMsg.at(i).read();
                if(buffer.at(newMessage.addr).size() >= bufferSize) continue;
                if(newMessage.isPrio) buffer.at(newMessage.addr).insert(0, newMessage); //<- ERROR OCCURS HERE
                else buffer.at(newMessage.addr).push_back(newMessage);
            }
        }

        ...
};

在注释行中出现以下错误:

error: no matching function for call to ‘std::vector<msg>::insert(int, msg&)’
     if(newMessage.isPrio) buffer.at(newMessage.addr).insert(0, newMessage);
                                                                          ^

为什么会出现错误?

buffer.at(newMessage.addr)std::vector <msg>因此应该使用msg类型的对象newMessage ...

感谢您的帮助!

1 个答案:

答案 0 :(得分:6)

std::vector::insert迭代器作为第一个参数,而不是索引。您可能想要这样:

void add_to_front(std::vector<msg> &vector, const msg &message)
{
  vector.insert(begin(vector), message);
}


if(newMessage.isPrio) add_to_front(buffer.at(newMessage.addr), newMessage);

我已将函数包装在一个函数中,因为它引用了两次向量,并且无论如何都会使代码读得更好。