概述
stl共性拷贝机制
stl元素放入容器 是拷贝进行的 是值寓意 而非引用寓意,
也就是说当我们给容器插入元素的时候,容器内部实施拷贝动作。
将我们要插入的元素再另行拷贝一份放入到容器中,而不是将原数据元素直接放进容器中,
也就是我们提供的元素必须能被拷贝。
解决方法 加入拷贝构造函数
1 除了queue 和stack 之外,每个容器都提供可返回迭代器的函数,
运用返回的迭代器可以访问元素
2 通常STL不会抛出异常 需要使用者传入正确参数
3 每个容器提供一个默认的拷贝函数 和 默认的拷贝构造函数
4 大小相关的构造方法 1 size()返回容器中的元素的个数 2 empty()判读容器是否为空
未加入拷贝构造函数前
加入拷贝构造函数后
代码如下
class Teacher{
public:
Teacher(char* name,int age){
int len = strlen(name) + 1;
this->name = new char[len];
//在堆分配内存
strcpy(this->name,name);
this->age = age;
}
//拷贝构造
如果没有这个程序容易崩溃
Teacher(const Teacher& t){
int len = strlen(t.name) + 1;
this->name = new char[len];
strcpy(this->name, t.name);
this->age = t.age;
}
//重载=
Teacher& operator=(Teacher& t){
int len = strlen(t.name) + 1;
if (this->name != NULL){
delete[] this->name;
}
this->name = new char[len];
strcpy(this->name, t.name);
this->age = t.age;
return *this;
}
~Teacher(){
if (this->name != NULL){
delete[] this->name;
}
this->age = 0;
}
char* name;
int age;
};
//测试函数
深拷贝和浅拷贝
程序在执行完test 会释放掉 会调用析构函数
void test01(){
Teacher t1("aaa",20);
vector<Teacher> v;
v.push_back(t1);
}
int main(){
test01();
system("pause");
return EXIT_SUCCESS;
}
最后
以上就是欢喜小鸭子为你收集整理的stl共性机制 与容器中的深拷贝与浅拷贝问题的全部内容,希望文章能够帮你解决stl共性机制 与容器中的深拷贝与浅拷贝问题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复