c++报错:
cannot call member function “virtual void A:: initialize()”without object
例题:16.1 还是困惑
https://www.xuebuyuan.com/944681.html
2.在我们使用初始化列表进行初始化时,要注意一个特性,它是关于C++初始化类成员的。它们是按照声明的顺序初始化的,而不是按照出现在初始化列表中的顺序。
例如:
class CMyClass {
CMyClass(int x, int y);
int m_x;
int m_y;
};
CMyClass::CMyClass(int i) : m_y(i), m_x(m_y)
{
}
你可能以为上面的代码将会首先做m_y=I,然后做m_x=m_y,最后它们有相同的值。但是编译器先初始化m_x,然后是m_y,,因为它们是按这样的顺序声明的。结果是m_x将有一个不可预测的值。
***
## 3.派生类的成员函数如何访问基类的构造函数 例题16.4
***
因为不能
为什么不能通过对象调用构造函数
打个比方,对象是个人的话,构造函数就是这个人的产生过程:或取资源,按照定义方式生长
而通过对象调用构造函数大概就是人已经出生了再进行一次出生前的过程了
构造函数不可以直接调用,这里的直接调用指的是像普通的成员函数那样调用
必须通过new运算符在创建对象时才会自动调用;而一般的方法是在程序执行到它的时候被调用的;
***
## 多态 虚函数出现的前况
***
Point & pRef = c; (point是基类 circle是派生类 c派生类对象)
定义了 Point类的引用变量pRef,并用派生类Circle对象c对其初始化。前面我们已经讲过,派生类对象可以替代基类对象为基类对象的引用初始化或赋值。现在 Circle是Point的公用派生类,因此,pRef不能认为是c的别名,它得到了c的起始地址, 它只是c中基类部分的别名,与c中基类部分共享同一段存储单元。所以用“cout<<pRef”输出时,调用的不是在Circle中声明的运算符重载函数,而是在Point中声明的运算符重载函数,输出的是“点”的信息,而不是“圆”的信息。 (就是还是调用的基类的成员函数)
***
## 纯虚函数的意义/抽象类
1.为了方便使用多态特性,我们常常需要在基类中定义虚拟函数。
2.在很多情况下,基类本身生成对象是不合情理的。例如,动物作为一个基类可以派生出老虎、孔雀等子类,但动物本身生成对象明显不合常理。
(四个字:制定标准
纯虚函数是为你的程序制定一种标准,即只要你继承了我,就必须按照我和标准来,实现我所有的方法,否则你也是虚拟的,和JAVA里的接口一样,都是制定标准,为了使程序更加通用化,可重用性提高,让所有实现它或继承自它的子类全部按同一标准来工作,你想想大家都按标准来对程序的益处是什么?)
(在很多情况下,基类本身生成对象是不合情理的。例如,动物作为一个基类可以派生出老虎、孔雀等子类,但动物本身生成对象明显不合常理。)
***
内联函数:
、是指用inline关键字修饰的函数。/并不一定就是在类的声明里展开函数体的啊
***
## 类模板
https://www.cnblogs.com/eleclsc/p/5918114.html or
https://www.cnblogs.com/gaojun/archive/2010/09/10/1823354.html
**c++警告**
int fuc(const char *a) //不加const 警告:deprecated conversion from string constant to 'char*'
{
cout << a << endl;
}
int main()
{
fuc("hello");
}
char *背后的含义是:给我个字符串,我要修改它。
而理论上,我们传给函数的字面常量是没法被修改的。
所以说,比较和理的办法是把参数类型修改为const char *。
这个类型说背后的含义是:给我个字符串,我只要读取它。
***
## 16.
***
strlen(s) : 返回S的长度,不包括字符串结束符NULL;
strcmp(s1,s2) :比较两个字符串是否相同,若s1==s2,返回0,若s1>s2则返回正数,若s1<s2则返回负数;
strcat(s1,s2):将字符串s2连接到s1上,返回 s1;
strcpy(s1,s2):将s2,复制到s1,返回 s1.
13.杨辉三角:(不考虑形状的话)
for (int i=0;i<n;i++)
a[i][0]=1;
for (int i=0;i<n;i++)
a[i][i]=1;
for (int i=1;i<n;i++)
{
for (int j=1;j<i;j++)//j<i是 因为a[n][n] 全是1了;j=0那一竖排也全是1;
a[i][j]=a[i-1][j-1]+a[i-1][j];//这句话是 重点!!!
}
12.小数点后四位输出
cout<<setiosflags(ios::fixed)<<setprecision(4)<<FUN(n)<<endl;
素数:质数定义为在大于1的自然数中,除了1和它本身以外不再有其他因数。(
if(i==1){ return 0;}
else if(i==2){ return 1;}
else {
for(int j=2;j<i;j++){
if(i%j==0){
return 0;
}
}
return 1;
}
c++再记
最新推荐文章于 2023-01-04 11:01:25 发布