ps:(我打算这边放一些具体学习工作的时候遇到的问题。放在本地太麻烦了。苦笑😂)
1. c++为什么不能在类中初始化成员变量(定义时候不能)?
(1)类只是一个抽象类型,并不是实体的东西,利用这个抽象类型会实例化成不同的个体,每个个体的特征(数据成员)都不一样,如果在类定义中将特征初始化了,岂不是破坏了抽象性,做了一个面向都一样的模子?
(2)类的定义实际相当与类型声明,并没有分配存储空间,初始化的数据哪里放? 类实例化以后才会有实体存储地址及空间。
C++初始化列表给数组初始化用{},最好用指针(相当复杂)
class base
{
char a[10];
public:
base():a{} //对构造函数用{}
{
...
}
}
class A
{
private:
int n1;
int n2;
public:
A():n2(0),n1(n2+2){}//通过构造函数 初始化成员变量
}
注意:类成员在定义时,是不能初始化的
注意:类中const成员常量必须在构造函数初始化列表中初始化。
注意:类中static成员变量,必须在类外初始化。
2.缺少类模板参数列表
在你进行template的模板定义后,如果是定义的类模板(c++结构体也一样)使用类时,需要加上参数:class1 A; class1是模板类。模板类是带参数的类
3.关于结构体指针(typedef struct后面加*指针)
typedef struct node
{
int data;
struct node *rchild,*lchild;
}node,*Node;
这里面的使用了typedef关键字,node就是替代了struct node的意思,而Node则代表了struct node*的意思,他指针指向了整个结构体。当你创建的是node T时,只能用T.data来表示数据
当你用Node指针创建时,Node T就可以用T->data来表示数据同时,struct node *rchild,*lchild;
可以直接Node rchild,lchild;
。
4. 关于c++中类型定义typedef和类模板能否共用问题
template<calss T>
typedef struct node
{
T data; //错误的
}node;
原因就在于typedef定义类型转变的时候必须是确定的类型