我有一堂课,看起来像这样:

class MemberListEntry {
public:
    int id;
    short port;
    long heartbeat;
    long timestamp;
    MemberListEntry(int id, short port, long heartbeat, long timestamp);
    MemberListEntry(int id, short port);
    MemberListEntry(): id(0), port(0), heartbeat(0), timestamp(0) {}
    MemberListEntry(const MemberListEntry &anotherMLE);
    MemberListEntry& operator =(const MemberListEntry &anotherMLE);
    int getid();
    short getport();
    long getheartbeat();
    long gettimestamp();
    void setid(int id);
    void setport(short port);
    void setheartbeat(long hearbeat);
    void settimestamp(long timestamp);
};


我有一些将其实例化的代码:

   int id = stoi(address.substr(0, pos));
   short port = (short)stoi(address.substr(pos + 1, address.size()-pos-1));
   memcpy(&addr[0], &id, sizeof(int));
   memcpy(&addr[4], &port, sizeof(short));

  MemberListEntry mEntry;
  mEntry = new MemberListEntry(id, port);


我收到此错误:

 error: no viable overloaded '='
 mEntry = new MemberListEntry(id, port);


任何想法可能是问题的原因吗?

最佳答案

您的代码应为

MemberListEntry * mEntry;
mEntry = new MemberListEntry(id, port);


您正在使用new运算符在堆上分配一个对象,该运算符返回指向所创建对象的指针,并且您正在尝试为该对象分配指针。

更好的替代方法是在堆栈上分配已经在做的对象。

MemberListEntry mEntry(id, port);

这将创建并初始化对象,并且当您的函数超出范围时,它将自动销毁。

有趣的事实:这不是Java,而是C ++。 :)

希望这可以帮助。

09-09 23:39
查看更多