C++提供了一种自定义类的机制,让程序员自己创造类型,来对应问题中的概念。类不但可以定义数据的复合,还可以定义该复合数据的操作。以便让本应由使用该数据类型的程序员做的工作分出来,让定义类型的程序员去完成。(与struct相像。)
由两部分组成:(1)类定义及其成员函数定义;类定义体中含有复合数据和成员函数声明。(2)应用部分。
class是一个关键字,它代表在下面的{...}中间声明一个类型.类在某些方面和C++中的struct很相似,但也有不同,比方说类有派生类,但是没人听说过派生结构吧.
那么class怎么用呢?
class A{ public: int a,b; void print() { cout << a << ' ' << b << '\n'; return ; } };
A t;
t.a = 10;
t.b = 5;
t.print();
输出:10 5类中总共有3中权限标识:public,private和protected.他们的区别是:public定义的成员可以被外部访问和修改;private成员不能被外部读取和修改,只能在类的内部使用,在派生类中无法访问;protected成员也不能被外部访问与修改,只能在内部使用,但是在派生类中将作为private成员使用.所以如果在定义类时,能够访问的就用public定义,不能访问就用protected定义.
接下来说说派生类.类的定义过程中你可能可能会发现有些东西会重复,比方说在定义了一个学生信息的类之后又要定义一个记录分数的类.如果用类里面套一个类会很麻烦,输入学生信息要用两个点,而重新构造类更麻烦了.所以C++提供了一个解决方案——派生类.
class stu{
protected:
string name, birthday;
int num;
public:
void print_data()
{
cout << "name: " << name << '\n';
cout << "number: " << num << '\n';
cout << "birthday: " << birthday << '\n';
}
};
这个是学生信息类.那么现在可以定义一个以它为基类的派生类score:
class score:public stu{
protected:
int score;
};
这样定义之后score类的对象将能够访问基类stu中的成员,并且加入成员score.
下面剩下一个构造函数与析构函数了.很多情况下我们需要在类对象创建的时候就执行一些代码.所以就有了构造函数与析构函数.
class stu{
protected:
int num;
string name, birthday;
public:
stu()
{
num = 0;
name = "";
birthday = "";
}
stu(int _num, string _name, string _bir)
{
num = _num;
name = _name;
birthday = _bir;
}
~stu(){}
};
上面这个类在定义时如果没有给对象传入参数则令num为0,name与birthday为空.传递参数的方法是在对象后面加一个括号传入参数.比如:
就等于给类中的构造函数传递参数,那么现在对象s中的num为123,name为"Xiaoming",birthday为"1900.1.1".