示例:在 OMNeT++ 中调试

Example: Debugging in OMNeT++

我知道,这可能要问很多,但谁能帮我调试这段代码:

#include <stdio.h>
#include <string.h>
#include <omnetpp.h>

using namespace omnetpp;


class Node : public cSimpleModule
{
  private:
    cMessage *out_msg;

    long no_sent = 0;
    long no_rcvd = 0;
    cOutVector rcvdRecord;
    cLongHistogram Statistics;

  public:
    Node();
    virtual ~Node();

  protected:
    virtual void initialize() override;
    virtual void handleMessage(cMessage *msg) override;
    virtual void finish() override;
};

Define_Module(Node);

Node::Node()
{
    out_msg = nullptr;
}

Node::~Node()
{
    delete out_msg;
}

void Node::initialize()
{
    out_msg = nullptr;

    if (strcmp("sender", getName()) == 0) {
        EV << "Scheduling first send to t=5.0s\n";
        scheduleAt(5.0, out_msg);
        out_msg = new cMessage("Sending Message");
    }
}

void Node::handleMessage(cMessage *msg)
{
    if (msg == out_msg) {
        EV << "Sending message to receiver\n";
        send(out_msg, "out");
        out_msg = nullptr;
        no_sent++;

        simtime_t delay = par("delayTime");
        scheduleAt(simTime() + delay, out_msg);
    }

        else {
            out_msg = msg;
            no_rcvd++;
            rcvdRecord.record(out_msg);
            Statistics.collect(out_msg); //what's going on here ?
    }
}

void Node::finish()
{
    EV << "Sent:     " << no_sent << endl;
    EV << "Received: " << no_rcvd << endl;
    EV << "Messages sent, mean:   " << Statistics.getMean() << endl;
    EV << "Messages sent, standard deviation: " << Statistics.getStddev() << endl;
    EV << "Messages sent, variance: " << Statistics.getVariance() << endl;
    recordScalar("#sent", no_sent);
    recordScalar("#received", no_rcvd);
    Statistics.recordAs("Message Statistics");
}

我收到以下错误消息:

Exercise2.cc:66:38: error: no matching function for call to 'omnetpp::cOutVector::record(omnetpp::cMessage*&)'

Exercise2.cc:67:39: error: no matching function for call to 'omnetpp::cLongHistogram::collect(omnetpp::cMessage*&)'

所以我真的不知道这应该告诉我什么。这些内置函数不是分别是 cOutVectorcLongHistogram 类 的一部分吗?

Aren't these built-in functions, part of the cOutVector or cLongHistogram classes respectively?

他们不是。好吧,cOutVector 确实有一个名为 record 的成员函数,它只是不能将 cMessage * 作为参数,所以 specific 函数 overload 你想使用不存在。与 cLongHistogramcollect.

相同

看看documentation:

A cOutVector object can write doubles to the output vector file ...

另外,作为 "histogram of messages",您究竟希望看到什么? :D This comic 我想到了...

要录制消息(不是 cOutVector),您可以启用 event logging. The resulting file can be visualized in the Sequence Chart tool of the IDE, see: https://docs.omnetpp.org/tutorials/tictoc/part2/#25-visualizing-on-a-sequence-chart