调程序,做的是第11周的,可是她写的程序(就在以下),呃,请读者自己执行一下吧。(下午在机房调试时用的是Code::Blocks10.05。输出的是非常长的莫名的符号,晚上在家用的是CodeBlocks12.11,典型的内存溢出症状。)
#include老贺及时来帮忙,单步执行是法宝。#include using namespace std;class Stu //声明基类{public: Stu(int n, string nam ):num(n),name(nam) {} //基类构造函数 void display( ); //成员函数,输出基类数据成员protected: //(*)訪问权限为保护型的数据成员[不能被外界引用但能够被派生类引用] int num; //学生学号 string name; //学生姓名};void Stu::display( ) //成员函数,输出基类数据成员{ cout<<"学号:"< <
在机房调试时用的是Code::Blocks10.05,51行定义并初始化对象s没有问题。顺利通过,而在52行s.show(),输出了莫名的文字。
再次单步,step into到s.show()中,发现混乱来自于39行输出name的地方。非常自然,name的值有问题。
name值是通过构造函数获取的,须要找源头。
问题出在39行,但思维必须得跳出show函数,找到真正的罪犯。
昏花的老眼看30行的构造函数,一眼就看出了冒号后面对基类构造函数的调用Stu(n,name)有蹊跷:形式參数中声明的是(int n, string nam, ...),而实际參数怎么就出来了(n,name)。去年一个字母e。构造函数的调用该为Stu(n,nam)。
编译再执行,小霍紧锁的眉头放开了。刚才还在怨着计算机的她,应该在反思着自己的大意了。
为何会这样?错误的调用,实际上在用未经初始化的基类成员name作实參,那初始化的结果,name成员仍然是那个“野对象”。string是C++中添加的类。当中的字符符串实际也是用指针实现的。未经初始化的对象,当中就有野指针。
写博文时用的是Code::Blocks12.11,单步执行时,51行的构造函数就下不去。焦点仍然能够锁定在派生类的构造函数上。问题仍能解决。
编程序,练的就是这番功力。
=================== 迂者 贺利坚 CSDN博客专栏=================|== ==||== ==||== 我写的书——《》 ==|===== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 ===== |