我有一个看起来像这样的课程:
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);
知道这个问题的原因是什么?
答案 0 :(得分:6)
您的代码应为
MemberListEntry * mEntry;
mEntry = new MemberListEntry(id, port);
您正在使用new运算符在堆上分配一个对象,该运算符返回指向所创建对象的指针,并且您正在尝试分配指向对象的指针。
这里更好的替代方案是在堆栈上分配对象,你已经在做了。
MemberListEntry mEntry(id, port);
这会创建并初始化对象,当您的函数超出范围时,它将自动被破坏。
有趣的事实:这不是java,它是C ++。 :)
希望这有帮助。