析构函数调用AFTER重载赋值运算符,调用-C++
Destructor call AFTER Overloaded Assignment Operator called - C++
我有一个名为*graph1的Graph指针,并且已经为它分配了内存(注意:这不是问题的一部分,但Graph是一个模板类)。我还创建了另一个名为graph2的Graph实例。我给他们打了一个过载的分配操作员的电话,就像一样
Graph<std::string,std::string> *graph1 = new Graph<std::string,std::string>;
...
... // Called member functions on graph1
Graph<std::string,std::string> graph2;
graph2 = *graph1;
赋值运算符工作正常,但由于某种原因,Graph的析构函数也会在赋值运算符被调用后立即被调用。这是正常的还是我没有正确执行赋值运算符?
这就是我如何实现分配运算符:
template <typename VertexType, typename EdgeType>
Graph<VertexType, EdgeType> Graph<VertexType, EdgeType>::operator=(const Graph<VertexType, EdgeType> &source)
{
std::cout << "tAssignment Operator callednn";
if(this == &source)
return *this;
this->vecOfVertices = source.vecOfVertices;
this->orderPtr = source.orderPtr;
this->count = source.count;
return *this;
}
赋值运算符的正确定义是
Graph<VertexType, EdgeType>& Graph<VertexType, EdgeType>::
operator=(const Graph<VertexType, EdgeType> &source);
通过使用Graph<VertexType, EdgeType>
作为返回类型,您生成了一个不必要的临时变量创建。
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对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函数,它却不起作用
- 构造函数正在调用一个使用当前类类型的函数
- 变量没有改变?通过向量的函数调用
- 没有为自己的结构调用列表推回方法
- 调用'begin(int [n])'没有匹配函数
- 什么时候调用析构函数
- 如何用参数值调用函数(仅在运行时已知)
- std::cout.imbue()多重调用
- 函数何时会在c++中包含stack_Unwind_Resume调用