博客
关于我
C++走向远洋——27(项目三,时间类)
阅读量:527 次
发布时间:2019-03-08

本文共 1131 字,大约阅读时间需要 3 分钟。

在分析了上述C++代码后,我发现该代码实现了一个基本的时间类,主要包括时间的设置、显示、以及时间的加法操作。代码的大致结构和功能如下:

  • 类定义:定义了一个名为Time的类,包含四个成员函数:

    • set_time():用于从标准输入读取时间字符串并设置时间。
    • show_time():用于输出当前时间。
    • add_a_sec():用于向后添加一秒。
    • add_a_minute():用于向后添加一分钟。
    • add_a_hour():用于向后添加一小时。
  • 输入处理:在set_time()函数中,通过cout输出提示信息,提示用户输入时间格式为"hh:mm:ss"。然后通过while(1)循环读取用户输入,并使用cin逐个读取小时、分钟和秒的字符,并解析为整数。

  • 时间验证:在is_time()函数中,检查输入的小时、分钟和秒是否在有效范围内。如果输入超出范围,则返回false,否则返回true。

  • 时间加法操作

    • add_a_sec():向后添加一秒,如果秒数超过59,则将秒数置为0,并将分钟数加1。
    • add_a_minute():向后添加一分钟,如果分钟数超过59,则将分钟数置为0,并将小时数加1。
    • add_a_hour():向后添加一小时,如果小时数超过23,则将小时数置为0。
  • 主函数:在main()函数中,创建一个Time对象,调用set_time()函数设置时间,然后依次调用add_a_sec()add_a_minute()add_a_hour()函数,最后调用show_time()函数显示当前时间。

  • 通过以上分析,我发现代码的主要问题在于以下几个方面:

  • 输入处理逻辑有误:在set_time()函数中,使用while(1)循环读取输入,但输入语句和条件判断有可能出错。特别是,cin >> hour >> c1 >> minute >> c2 >> sec会导致小时、分钟、秒都被赋值为整数,可能会混淆用户输入的字符。

  • 逻辑错误:在is_time()函数中,检查条件写错了,h> 24应该是h >=24,但原代码中写成h> 24,这会导致所有24小时的时间都被拒绝。

  • 进位处理错误:在add_a_sec()函数中,秒数增加后,检查是否超过59,但没有正确处理进位到分钟。同样,add_a_minute()函数进位到小时的逻辑可能有问题。

  • 类名拼写错误:在Time::add_a_sec函数中,类名写成了time,这可能会导致编译错误。

  • 缺少必要的包含文件<iostream><string>等必要的C++标准库文件没有包含,可能导致编译错误。

  • 基于以上分析,我需要修正这些问题,确保代码能够正确运行,处理时间的增减,并且输入和输出都符合预期。

    转载地址:http://tdgnz.baihongyu.com/

    你可能感兴趣的文章
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm 下载依赖慢的解决方案(亲测有效)
    查看>>
    npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
    查看>>
    npm.taobao.org 淘宝 npm 镜像证书过期?这样解决!
    查看>>
    npm—小记
    查看>>
    npm上传自己的项目
    查看>>
    npm介绍以及常用命令
    查看>>
    NPM使用前设置和升级
    查看>>
    npm入门,这篇就够了
    查看>>
    npm切换到淘宝源
    查看>>
    npm切换源淘宝源的两种方法
    查看>>
    npm前端包管理工具简介---npm工作笔记001
    查看>>
    npm包管理深度探索:从基础到进阶全面教程!
    查看>>
    npm升级以及使用淘宝npm镜像
    查看>>
    npm发布包--所遇到的问题
    查看>>
    npm发布自己的组件UI包(详细步骤,图文并茂)
    查看>>
    npm和package.json那些不为常人所知的小秘密
    查看>>
    npm和yarn清理缓存命令
    查看>>
    npm和yarn的使用对比
    查看>>
    npm如何清空缓存并重新打包?
    查看>>