标签:cout c++ MyClass 拷贝 赋值 array size
拷贝赋值
注意事项:拷贝赋值前有new一个空间记得在拷贝赋值时清空,详细看代码
#include<iostream>
#include<string>
using namespace std;
class MyClass
{
friend ostream& operator<<(ostream &in, const MyClass& a1);//cout的读取
public:
MyClass(int size)//构造一个空间
{
cout << "构造"<< endl;
m_array=new int[size];
m_size=size;
}
MyClass(const MyClass &arr)//拷贝数组
{
cout << "拷贝构造" << endl;
m_array = new int[arr.m_size];//new一个空间传递数组
/*
memcpy内存拷贝(dest新缓冲区,src从中进行复制操作的缓冲区,count要复制的字符数。
arr.m_size*sizeof(arr.m_array[0])读取字符数
memcpy 将字节 count 从 复制到 src dest ;
返回值为dest
*/
memcpy(m_array, arr.m_array, arr.m_size*sizeof(arr.m_array[0]));
m_size = arr.m_size;
}
MyClass& operator=(const MyClass &tate)//相当于重新拷贝构造一遍
{
if (&tate != this)//判断是否重复拷贝赋值自己
{
if (this->m_array)//判断是否为空,清空上一次new的一个空间
{
delete[] m_array;
m_array = NULL;
}
//拷贝赋值和拷贝构造差不多,但是之前如果有new一个空间必须清空。
//拷贝*pless1就是重新给值然后赋值到*pless2。
cout << "拷贝赋值" << endl;
m_array = new int[tate.m_size];
memcpy(m_array, tate.m_array, tate.m_size*sizeof(tate.m_array[0]));
m_size = tate.m_size;
return *this;
}
cout << "拷贝构造自己" << endl;
return *this;
}
int &at(int index)//接收数组
{
return m_array[index];
}
size_t size()//返回数组
{
return m_size;
}
~MyClass()//析构
{
if (m_array){
delete[] m_array;
m_array = NULL;
}
}
private:
int *m_array;
size_t m_size;
};
ostream& operator<<(ostream &in, const MyClass& a1)//输出
{
for (int i = 0; i < a1.m_size; ++i)
{
in << a1.m_array[i] << ' ';
}
in << endl;
return in;
}
int main()
{
//构造函数
MyClass *pless1 = new MyClass(4);
for (int i = 0; i < pless1->size(); ++i)
{
pless1->at(i) = i;//赋值
}
cout << *pless1 << endl;
//拷贝构造
MyClass* pless2 = new MyClass(*pless1);
cout << *pless2 << endl;
//拷贝赋值
*pless2 = *pless1;
cout << *pless2 << endl;
//拷贝赋值自己
*pless2 = *pless2;
cout << *pless2 << endl;
system("pause");
}
标签:cout,c++,MyClass,拷贝,赋值,array,size 来源: https://blog.csdn.net/weixin_45357007/article/details/120301150
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。