记录:50多行程序中找出多写的一个字母e

简介:   小霍同学调程序,做的是第11周的项目1 - 存储班长信息的学生类,但是她写的程序(就在下面),呃,请读者自己运行一下吧。(下午在机房调试时用的是Code::Blocks10.05,输出的是很长的莫名的符号,晚上在家用的是CodeBlocks12.11,典型的内存溢出症状。)#include <iostream>#include <string>using n

  小霍同学调程序,做的是第11周的项目1 - 存储班长信息的学生类,但是她写的程序(就在下面),呃,请读者自己运行一下吧。(下午在机房调试时用的是Code::Blocks10.05,输出的是很长的莫名的符号,晚上在家用的是CodeBlocks12.11,典型的内存溢出症状。)

#include <iostream>
#include <string>
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<<"学号:"<<num<<endl;
    cout<<"姓名:"<<name<<endl;
}
class StuDetail: public Stu              //声明派生类StuDetail
{
public:
    //学生nam,学号n,a岁,家住ad,他的班长是nam1,学号n1
    StuDetail(int n, string nam,int a, string ad,int n1, string nam1); //派生类构造函数
    void show( ); //成员函数,输出学生的信息
    void show_monitor( );    //成员函数,输出班长信息
private:
    Stu monitor;   //学生所在班的班长,班长是学生,是Stu类的成员
    int age;       //学生年龄
    string addr;   //学生的住址
};
StuDetail::StuDetail(int n, string nam,int a, string ad,int n1, string nam1):Stu(n,name),monitor(n1,nam1)
{
    age=a;
    addr=ad;
}
void StuDetail::show( ) //成员函数,输出学生的信息
{
    cout<<"学生信息:"<<endl;
    cout<<"学号:"<<num<<endl;
    cout<<"姓名:"<<name<<endl;
    cout<<"年龄:"<<age<<endl;
    cout<<"住址:"<<addr<<endl;
}
void StuDetail::show_monitor( )   //成员函数,输出班长信息
{
    cout<<"班长信息:"<<endl;
    monitor.display();
}
int main( )
{
    //学生王力,10010号,19岁,家住上海的北京路,他的班长是李孙,学号10001
    StuDetail s(10010,"Wang-li",19,"115 Beijing Road,Shanghai",10001,"Li-sun");
    s.show( );                       //输出学生信息
    s.show_monitor();                //输出班长信息
    return 0;
}
  老贺及时来帮忙,单步执行是法宝。

  在机房调试时用的是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学子成长指导专栏 专栏文章的分类目录(不定期更新) ==|
|== C++ 课堂在线专栏  贺利坚课程教学链接(分课程年级) ==|
|== 我写的书——《逆袭大学——传给IT学子的正能量》    ==|
===== 为IT菜鸟起飞铺跑道,和学生一起享受快乐和激情的大学 =====



目录
相关文章
|
1月前
|
监控 Cloud Native Java
阿里云可观测联合 Datadog 发布 OpenTelemetry Go 自动插桩工具
阿里云联合社区推出 OpenTelemetry Go 编译时自动插桩方案,基于 -toolexec 实现零代码修改的链路追踪与监控,支持 HTTP、gRPC 等常用框架,低开销、高兼容,助力 Go 应用无缝接入可观测体系。
150 2
|
1月前
|
Web App开发 人工智能 运维
2025年主流Web自动化测试工具功能与适用场景对比
文章围绕2025年主流Web自动化测试工具展开,介绍行业发展趋势与痛点,对比优测、Selenium等工具的功能、优势、劣势及适用场景。指出不同工具呈差异化路径,企业应依团队技术、业务需求和预算选适配方案,还解答了工具选择、协同使用等常见问题。
|
1月前
|
存储 缓存 前端开发
HTTP 缓存详解
HTTP缓存是提升网页性能的核心机制,通过“强制缓存”和“协商缓存”减少请求、节省带宽。强制缓存由浏览器判断是否过期(如Cache-Control),未过期则直接使用本地资源;过期后进入协商缓存,服务器通过Etag或Last-Modified判定资源是否变更,可复用则返回304。合理配置缓存策略,能显著提升加载速度与用户体验。
210 3
|
1月前
|
Web App开发 安全
Chrome浏览器自动拦截某些下载内容 解决方案
Chrome下载文件常因安全机制被拦截。可通过设置允许不安全内容解决:在地址栏输入`chrome://settings/content/insecureContent`,添加`[*.]com`等域名,即可免手动确认下载。建议按需添加,兼顾安全与便利。(239字)
741 3
Chrome浏览器自动拦截某些下载内容 解决方案
|
1月前
|
SQL XML JavaScript
【RuoYi-Eggjs】:将若依带入 Node.js 世界的企业级后台管理系统
RuoYi-Eggjs 是基于 Egg.js 的企业级后台系统,100% 复刻若依功能,支持 MyBatis XML 风格 SQL、多数据库、JWT 认证、权限控制与代码自动生成,完美对接 RuoYi-Vue3 前端,助力 Node.js 开发者高效构建管理系统。
153 5
|
1月前
|
人工智能 数据可视化 物联网
大模型微调技术入门:从核心概念到实战落地全攻略
本课程系统讲解大模型微调核心技术,涵盖LoRA、QLoRA等高效方法,结合ComfyUI与主流工具实战,从数据准备到模型部署全流程落地,助力开发者低成本定制专属AI模型。
|
1月前
|
JavaScript 前端开发
如何实现前端大量的DOM数据加载而页面不卡顿
为避免大量DOM导致页面卡顿,可采用分批渲染或虚拟滚动技术,仅渲染可视区域内容。
144 3
|
30天前
|
SQL 数据可视化 Java
Metabase 简介
Metabase 是一款开源数据可视化工具,支持多种数据库,提供直观的查询、仪表板和自动化报告功能。通过 Docker 或 JAR 快速部署,具备权限管理、SSO 集成与缓存优化,适合技术与非技术人员高效分析数据。
|
1月前
|
JavaScript 前端开发 IDE
前端开发项目必备VSCode代码定位神器——code-inspector-plugin
本文介绍了一款由快手前端团队开发的高效开发工具——code-inspector-plugin。该插件可实现点击页面DOM元素,自动定位至IDE中对应源码行,支持Vue、React等主流框架及Webpack、Vite等多种构建工具,无侵入、易集成,大幅提升前端开发调试效率。
254 0
|
1月前
|
前端开发 JavaScript

热门文章

最新文章