繁体   English   中英

C ++重载:运算符的重载=

[英]c++ overloading: overload of operator =

我有一些问题,而运算符=的重载。 我的代码是

#include <stdlib.h>
#include <iostream>


const std::size_t DIM = 10;


template <typename T>

class rowvec
  {
    private:
      T* m_pnt;
      std::size_t m_dim;

    public:
      rowvec();
      rowvec(std::size_t);
      ~rowvec();

      rowvec<T>& operator=(const rowvec<T>& x);

      T* pnt();
  };


template <typename T>
rowvec<T>::rowvec()
  {
    m_dim = DIM;
    m_pnt = (T*) calloc (DIM ,sizeof(T));
  }


template <typename T>
rowvec<T>::rowvec(std::size_t n)
  {
    m_dim = n;
    m_pnt = (T*) calloc(m_dim,sizeof(T));
  }


template <typename T>
rowvec<T>::~rowvec()
      {free(m_pnt);}


template <typename T>
rowvec<T>& rowvec<T>::operator=(const rowvec<T> &x)
  {
    std::cout << "hello" << std::endl;
    if (this != &x)
      {
        free (m_pnt);
        this->m_dim=x.m_dim;
        m_pnt = (T*) calloc (m_dim,sizeof(T));
        for (int i=0; i!=m_dim; i++)
          *(m_pnt+i)=*(x.m_pnt+i);
      }
    return *this;
  }


template <typename T>
T* rowvec<T>::pnt()
  {return m_pnt;}  




int main()
  {
    rowvec<int> k(3);

    rowvec<int> c=k;

    std::cout << "ok" << std::endl;

    return 0;
  } 

没有编译错误,但是运行时的结果是:

ok
*** Error in `./blog': double free or corruption (fasttop): 0x0000000001a5e010 ***

如果我以这种方式更改代码:

int main()
  {
    rowvec<int> k(3);

    rowvec<int> c;

    c=k;

    std::cout << "ok" << std::endl;

    return 0;
  }

一切都很好(输出是)

hello
hello
ok

有没有办法允许像“ rowvec c = k;”这样的声明?

即使其中有=rowvec<int> c=k; 是复制初始化,并使用复制构造函数而不是复制分配运算符。

由于您的类没有定义一个,因此将使用仅执行成员级复制的默认类。 那只会复制指针,这会导致双精度释放,因为ck的析构函数都将在同一指针上调用free()

给您的类一个适当的复制构造函数(进行深复制),然后应该删除双重删除。

另外,您正在使用C ++。 不要使用calloc / free 使用newdelete

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM