堆栈调用析构函数,即使遵循三规则
Stack calling destructor even after following the rule of three
每次我将一个对象推送到我的堆栈中时,它都会调用它为析构函数。我认为这是因为它正在制作一个临时对象,推动它,然后破坏临时对象。
enum State{Empty, Main, Menu};
class StateInfo{
public:
StateInfo(State state);
~StateInfo();
StateInfo(const StateInfo& otherState);
StateInfo& operator=(const StateInfo& otherState);
private:
std::string _stateType;
State _state;
};
析构函数只是打印一条消息,指出_stateType已被销毁。copy 和 = 函数只是将 _stateType 和 _state = 设置为另一个状态。
当我制作一个堆栈并推送和反对它时:
std::stack<StateInfo> _stateStack;
_stateStack.emplace(StateInfo(State::Main));
我收到一条消息,说已调用析构函数。
您应该将语句替换为:
_stateStack.emplace(State::Main);
然后,将就地创建对象,将State::Main
传递给它的构造函数。您显式创建了临时StateInfo
强制复制或移动 ctor 调用(和析构函数)。
你应该将参数传递给State
的构造函数直接传递给emplace()
:
_stateStack.emplace(State::Main);
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 函数调用中参数的顺序重要吗
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 在c++类上调用void函数
- 为什么 std::unique 不调用 std::sort?
- 调用专用模板时出错"no matching function for call to [...]"
- 此代码是否违反一个定义规则
- 选择要调用的构造函数
- C++为什么尽管我调用了void函数,它却不起作用
- 构造函数正在调用一个使用当前类类型的函数
- 变量没有改变?通过向量的函数调用
- 强制实施调用函数应向被调用函数返回的值添加常量的规则
- 严格别名规则是否适用于跨函数调用
- 使用经典重载解析规则创建依赖于 std::调用的重载集类
- 堆栈调用析构函数,即使遵循三规则
- 如何从精神语义规则绑定/调用存储在fusion::vector中的boost::函数