C++类基础

  1. 关于空类

(1)C++中定义一个空的类型时类,里面没有任何成员变量和成员函数,对该类型求sizeof时,得到的结果应该是1,而不是0,因为空类型中不包含任何信息,本来应该是0,但是当我们声明该类型的实例的时候,必须在内存中占有一定的空间,否则无法使用这些类型,至于占用多少内存由编译器决定,在Visual Studio中每个空类型的实例占用一个字节的空间。

(2)当在空类中添加一个构造函数和析构函数时若再求sizeof结果仍然是1,因为调用构造函数和析构函数只需要知道函数的地址即可,而这些函数的地址只与类型有关,而与类型的实例无关,编译器也不会因为这两个函数而在实例内添加任何额外的信息。

(3)将析构函数标记为虚函数时:C++中编译器一旦发现一个类型中有虚函数,就会为该类型生成虚函数表,并且在该类型的每一个实例中添加一个指向虚函数的指针。在32位的机器上,一个指针占4字节的空间,因此求sizeof得到的是4.在64位的机器上,一个指针占8字节的空间,因此求sizeof得到的是8.

  2.关于类

   (1)不说明访问限定符时,函数默认为私有访问

   (2)普通的成员变量调用时都要依赖对象来调用

  3.关于类中的默认成员方法

(1)构造函数:构造函数名与类名相同。作用是(1)开辟内存(2)给开辟的内存进行初始化  

                        :不带参数的构造函数称为默认构造函数 。构造函数可以重载。

                       :构造函数初始化以后不可再手动调用构造函数

(2)析构函数:作用清理资源,释放内存。(栈上的系统自己清理,堆上的需要手动清理)

                       :先构造的后析构 不可重载 系统默认析构函数不会清理堆内存 如果不手动清除会导致内存泄漏

                       :析构函数可以自主调用,手动自主调用时即退化为普通成员方法

(3)拷贝构造函数:用一个已存在的对象生成一个相同类型的新对象。默认拷贝构造函数时浅拷贝,在有堆内存上的数据使用时会出错。

                         :拷贝构造函数传入的参数是一个const 类名& 类型的形参 ,因为&不用开辟新的空间,相当于指针指向实参类。而且使用引用可以防止递归调用拷贝构造形参对象的情况。const防止右操作数的对象被修改。

(4)赋值运算符的重载函数:将一个已存在的对象赋值给另外一个已存在的对象

       赋值运算符的重载函数实现步骤:①判断是否为自赋值②释放被赋值的资源③实现拷贝(浅拷贝,深拷贝,写实拷贝)

     赋值运算符的重载函数的函数名 :例如:Goods& operator=(const CGoods& rhs)

      分析:①只有返回一个引用才可以允许连续赋值,否则如果函数的返回值是void,该赋值运算符将不能做连续赋值。例如CGoods有三个对象good1=good2=good3,就不能编译通过。

               ②传入的参数类型不是引用而是实例,那么从形参到实参就会调用一次拷贝构造函数。设置为引用避免了无用的消耗。

              ③实现时的自赋值判断:如果是同一个对象就不进行复制操作直接返回。如果不事先判断,那么在释放对象的旧资源时就会出现严重问题。当this与传入的参数是同一个对象是,一旦释放了自身的内存,传入的参数也被释放了,就会出现错误。

//范例
	void operator=(const CGoods& rhs)
	{
		cout << this << "void operator=(const CGoods&)" << " <== " << &rhs << endl;
		if (this != &rhs)
		{
			delete[] mname;
		        mname = new char[strlen(rhs.mname) + 1]();
		        memcpy(mname, rhs.mname, strlen(rhs.mname) + 1);
		        mamount = rhs.mamount;
		        mprice = rhs.mprice;
		}
		return *this;
	}

在赋值运算符重载函数中还有以下问题需要注意:

①隐式生成临时对象:good1=10;

   显示生成临时对象:good1=CGoods(10);

  这些临时对象的生成周期在表达式结束

②在此函数中形参const的作用:一是防止实参被修改,二是接收隐式生成的临时量

③类类型的返回值由临时对象带出来,调用函数时形参会先调用拷贝构造函数生成临时对象。

④临时对象的优化:临时对象的生成目的如果是为了生成新的对象则会以生成临时对象的方式来生成新的对象。

⑤禁止隐式生成临时对象关键字:explicit

猜你喜欢

转载自blog.csdn.net/Monster7559/article/details/84777334