c++类大四个默认函数-构造函数 析构函数 拷贝构造函数 赋值构造函数

  每个类只有一个析构函数和一个赋值函数,但可以有多个构造函数(包含一个拷贝构造函数,其它的称为普通构造函数)。对于任意一个类A,如果不编写上述函数,C++编译器将自动为A 产生四个缺省的函数,例如:

  A(void);//缺省的无参数构造函数

  A(const A&a);//缺省的拷贝构造函数

  ~A();//缺省的析构函数

  A&operator=(const A &a);//缺省的赋值构造函数

1)、“缺省的拷贝构造函数”和“缺省的赋值函数”均采用“位拷贝”而非“值拷贝”的方式来实现,倘若类中含有指针变量,这两个函数注定将出错。

2)、当类还没有生成的时候,调用大是拷贝构造函数,当类已经生成的时候,调用的是赋值构造函数,如下所示:

  A a;

  A b;

  b = a;//此时类a和b都已经生成了,所以调用的是赋值构造函数

  A c;

  A d=c;//此时类d还没有生成,所以调用的是拷贝构造函数

3)、所有的函数调用传参数,调用的都是拷贝构造函数。如果函数参数用的是引用类型,则不会发生参数的拷贝,也就不会调用任何函数了。

如下:

  void print_a(const A a);//调用拷贝构造函数

  void print_b(const A &a);//为引用,不会调用任何函数

4)、拷贝构造函数和赋值构造函数对实现。

  A::A(const A&a)

  {

  }

  拷贝构造函数没有返回,为一个全新的类。

  A &A::operator=(const A&a)

  {

    return *this;

  }

  赋值构造函数返回自身,即*this,为在原先的类上大操作。

时间: 2024-10-09 17:24:10

c++类大四个默认函数-构造函数 析构函数 拷贝构造函数 赋值构造函数的相关文章

C++中的默认函数 深拷贝与浅拷贝 深赋值与浅赋值

1.C++中什么都不写,就有6个默认函数,由系统自动提供: 构造函数,拷贝构造函数,赋值语句,析构函数,对一般对象的取地址符,对常对象的取地址重载: 对&运算符的重载: Test t3; Test *pt = &t3; Test* operator&(){     return this; } 对常对象的取地址重载: const Test t4; const Test *pt1 = &t4; const Test* operator&()const{     ret

【C/C++学院】(6)构造函数/析构函数/拷贝构造函数/深copy浅copy

1.构造函数 类的初始化即为构造函数.也为:隐式的初始化. 构造函数在对象初始化的时候,自动被调用.隐式的调用. 构造函数分为三种:有参构造函数.无参构造函数.拷贝构造函数. 有参构造函数调用有三种:括号法.等号法.手工法. #include <iostream> using namespace std; class Test { private: int m_a; public: Test()//无参构造函数 { } Test(const Test &obj)//拷贝构造函数 { }

C++中的默认函数与default和delete用法

时间:2014.05.08 地点:基地 -------------------------------------------------------------------------------- 一.类中的默认函数 a.类中默认的成员函数 1.默认构造函数 2.默认析构函数 3.拷贝构造函数 4.拷贝赋值函数 5.移动构造函数 6.移动拷贝函数 b.类中自定义的操作符函数 1.operator 2.operator& 3.operator&& 4.operator* 5.op

CPP_类默认函数:构造函数,拷贝构造函数,赋值函数和析构函数

类默认函数:构造函数,拷贝构造函数,赋值函数和析构函数 class Person{ public : Person():age(10), name(NULL); Person(int myage, char *myname); Person(const Person &a); ~Person(void); void set_age(int myage); void get_age(void); void set_other_age(Person &a, int b); private: i

【编程题】编写String类的构造函数、拷贝构造函数、析构函数和赋值函数

[编程题]编写String类的构造函数.拷贝构造函数.析构函数和赋值函数 [题目]:请编写如下4个函数 1 class String 2 { 3 public: 4 String(const char *str = NULL);// 普通构造函数 5 String(const String &other); // 拷贝构造函数 6 ~ String(void); // 析构函数 7 String & operate =(const String &other);// 赋值函数 8

为什么构造函数不能声明为虚函数,析构函数可以

构造函数不能声明为虚函数,析构函数可以声明为虚函数,而且有时是必须声明为虚函数.不建议在构造函数和析构函数里面调用虚函数. 构造函数不能声明为虚函数的原因是:1 构造一个对象的时候,必须知道对象的实际类型,而虚函数行为是在运行期间确定实际类型的.而在构造一个对象时,由于对象还未构造成功.编译器无法知道对象 的实际类型,是该类本身,还是该类的一个派生类,或是更深层次的派生类.无法确定... 2 虚函数的执行依赖于虚函数表.而虚函数表在构造函数中进行初始化工作,即初始化vptr,让他指向正确的虚函数

C++:类中两个易被忽略的默认函数

C++的自定义类中有六个默认的函数,即如果用户没有显式定义这些函数时,C++编译器会类中生成这些函数的默认形式.除了大家所熟知的构造函数.拷贝构造函数.赋值函数和析构函数外,C++为自定义类 还提供了两个容易被人忽视的默认函数--取地址函数和对常对象的取地址函数. 一.取地址函数 在C++中可以通过取地址运算符&求得变量的地址,如: 1 int a=10; 2 cout<<"变量a的地址为:"<<&a<<endl; 那么对于自定义类的

一个空类被编译器编译后产生了哪些默认函数

为何空类的大小不是0呢? 为了确保两个不同对象的地址不同,必须如此. 类的实例化是在内存中分配一块地址,每个实例在内存中都有独一无二的二地址. 同样,空类也会实例化,所以编译器会给空类隐含的添加一个字节,这样空类实例化后就有独一无二的地址了. 所以,空类的sizeof为1,而不是0. 一个空的class在C++编译器处理过后就不再为空,编译器会自动地为我们声明一些member function, 如果你写 class A{}; 编译器处理后,就相当于: class A { public: A()

C++之中this指针与类的六个默认函数小结

我们先来看看this指针.之前看过一篇关于this指针的文章,觉得写的很好,今天决定自己来写一写,顺便总结一下C++里面关于类的一些内容. 什么是this指针呢?简单的说它是一个指向类的实例的指针,就好像当我们在进入一个房子之后,可以看见房子里的桌子,椅子.地板等, 但是看不到房子的全貌.对于一个类的实例来说,你可以看到它的成员函数.成员变量,但是实例本身呢?this是一个指针,它时时刻刻指向这个实例. 来看看this指针的特性: 1)this指针的类型是一个类类型 * const, 这表示什么