1 /*********************************************************************
2 小技巧:
3 1、在以后的MFC编程中,如果在成员函数中想调用同类中的某个成员,可以使用VC++提供的自动列出成员函数功能,
4 使用this->,VC++将列出该类中的所有成员,我们可以从列表中选择我们想调用的成员。
5 2、自动列出成员函数功能,可以提高编写速度,减少拼写错误。我们经常不能完全记住某个函数的完整拼写,
6 但却能够从列表中辨别出该函数,自动列出成员函数的功能在这时就显得更加有用了。事实上,在各种IDE编程环境中,
7 我们通常都不可能记住也没有必要记住所有的函数,只要将常用的函数记住,其他不常用的函数只要记住其大概的写法和功能,
8 在调用该函数时可以从自动列出成员函数中选取,这样可以大大节省我们的学习时间。
9 我们不用花费大量的时间去死记硬背许多函数,利用自动列出成员函数功能和帮助系统,
10 就能够在编程时顺利地使用这些函数,等用的次数多了,也就在不知不觉中完全掌握了这些函数。
11 **********************************************************************/
12 #include <iostream>
13 using namespace std;
14 class Point
15 {
16 public:
17 int x;
18 int y;
19 /*********************************************************************
20 构造函数可以用来初始化类内部的成员变量
21 1、构造函数 最重要的作用是创建对象本身
22 2、C++规定,每个类必须有一个构造函数,没有构造函数就不能创建对象本身
23 3、C++又规定,如果一个类没有提供任何的构造函数,则C++提供一个默认的构造函数(由C++编译器提供),
24 这个默认的构造函数是一个不带参数的构造函数,它只负责创建对象,而不做任何的初始化工作。
25 4、只要一个类定义了一个构造函数,不管这个构造函数是否是带参数的构造函数,C++就不再提供默认的构造函数。
26 也就是说,如果为一个类定义了一个带参数的构造函数,还想要无参数的构造函数,则必须自己定义。
27 *********************************************************************/
28 Point(){ //构造函数,无返回值,可以带参数
29 x = 1;
30 y = 2;
31 }
32 /*********************************************************************
33 函数的重载
34 重载构成的条件:函数的参数类型、参数个数不同,才能构成函数的重载。
35 **********************************************************************/
36 Point(int a,int b){ //函数重载
37 x = a;
38 y = b;
39 }
40 /*********************************************************************
41 析构函数
42 1、当一个对象生命周期结束时,其所占有的内存空间就要被回收,这个工作就由析构函数来完成。
43 2、析构函数是“反向”的构造函数,析构函数不允许有返回值,更重要的是析构函数不允许带参数,
44 并且一个类中只能有一个析构函数。
45 3、析构函数的作用正好与构造函数相反,对象超出其作用范围,对应的内存空间被系统收回或被程序用delete删除时,析构函数被调用。
46 4、根据析构函数的这种特点,我们可以在构造函数中初始化对象的某些成员变量,
47 给其分配内存空间(堆内存),在析构函数中释放对象运行期间所申请的资源。
48 *********************************************************************/
49 ~Point(){ } //析构函数用于在类对象生命周期结束的时候,释放类对象的内存空间。析构函数不允许带参数
50 void outc(){
51 cout<<"x = "<<x<<endl;
52 cout<<"y = "<<y<<endl;
53 }
54
55 /*********************************************************************
56 this指针
57 1、this指针是一个隐含的指针,它是指向对象本身,代表了对象的地址
58 2、一个类所有的对象调用的成员函数都是同一代码段。那么成员函数又是怎么识别属于同一对象的数据成员呢?
59 原来,在对象调用pt.output(10,10)时,成员函数除了接受2个实参外,还接受到了一个对象s的地址。
60 这个地址被一个隐含的形参this指针所获取,它等同于执行this=&pt。
61 所有对数据成员的访问都隐含地被加上前缀this->。例如:x=0; 等价于 this->x=0。
62 *********************************************************************/
63 void outc(int x,int y){
64 this->x = x;
65 this->y = y;
66 }
67 };
68
69 void main()
70 {
71 Point Pt[2];
72 //Pt[0].x = 1;
73 //Pt[1].x = 2;
74 //Pt[0].y = 3;
75 //Pt[1].y = 4;
76
77 Pt[0].outc();
78 Pt[1].outc(5,5);
79 Pt[1].outc();
80 //cout<<"pt[0]="<<pt[0].x<<endl;
81 //cout<<"pt[1]="<<pt[1].x<<endl;
82 //cout<<"pt[0]="<<pt[0].y<<endl;
83 //cout<<"pt[1]="<<pt[1].y<<endl;
84 }