我有一堂课,看起来像这样:
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 ++。 :)
希望这可以帮助。