C++之“流”-第1课.下:实战:最简日志系统的演化

2024-05-28 12:52

本文主要是介绍C++之“流”-第1课.下:实战:最简日志系统的演化,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

五个版本的 C++ “流”式日志系统的演化,零基础也能轻松跟进!

 1. 面向抽象编程

本课的学习重点是面向对象思想中的“向向抽象 / 接口编程,而非面向实体编程”。在C++标准库中, ostream / istream 这些抽象流(见上一节)就是抽象,对应的,具体的控制台流、内存流、文件流就是实体。

“面向抽象流” 编写日志系统,则后续课程中实现 “流式风格的日志系统”的基础。前者的学习,注重思想上的理解,后者则更多的是技巧上的学习。

2. 课堂视频

C++之“流”-第2课:最简单的流式日志系统

3. 完整代码

我们用了五个版本演进,帮助大家理解实际项目需求的常见进化,以及对应的设计改进。

3.1 版本一:手工写日志

#include <iostream>using namespace std;int main()
{cout << "【信息】:" << "即将输出你好世界!" << endl;cout<<"你好,世界!" << endl;cout << "【信息】:" << "完成输出你好世界!" << endl;cout << "【信息】:" << "终于不辱使命,即将全身而退。" << endl;
}

3.2 版本二:用上函数,减少重复

#include <iostream>
#include <string>using namespace std;void OutputDebugInfo(std::string const& debug_info)
{cout << "【信息】:" << debug_info << endl;
}int main()
{OutputDebugInfo("即将输出你好世界!");cout<<"你好,世界!" << endl;OutputDebugInfo("完成输出你好世界!");OutputDebugInfo("终于不辱使命,即将全身而退。");
}

3.3 版本三:把日志写入文件!

#include <iostream>
#include <string>
#include <fstream>using namespace std;void OutputDebugInfo(ofstream& ofs, std::string const& debug_info)
{ofs << "【信息】:" << debug_info << endl;
}int main()
{ofstream ofs ("log.txt");OutputDebugInfo(ofs, "即将输出你好世界!");cout<<"你好,世界!" << endl;OutputDebugInfo(ofs, "完成输出你好世界!");OutputDebugInfo(ofs, "终于不辱使命,即将全身而退。");
}

3.4 版本四:改用抽象的流

#include <iostream>
#include <string>
#include <fstream>using namespace std;void OutputDebugInfo(ostream& os, std::string const& debug_info)
{os << "【信息】:" << debug_info << endl;
}int main()
{ofstream ofs ("log.txt");OutputDebugInfo(ofs, "即将输出你好世界!");cout<<"你好,世界!" << endl;OutputDebugInfo(ofs, "完成输出你好世界!");OutputDebugInfo(cout, "终于不辱使命,即将全身而退。");
}

3.5 版本五:看,这不也支持“内存流”?

#include <iostream>
#include <string>
#include <fstream>
#include <sstream>using namespace std;void OutputDebugInfo(ostream& os, std::string const& debug_info)
{os << "【信息】:" << debug_info << endl;
}int main()
{ofstream ofs ("log.txt");OutputDebugInfo(ofs, "即将输出你好世界!");cout<<"你好,世界!" << endl;ostringstream oss;OutputDebugInfo(oss, "估计要出错了哦……");OutputDebugInfo(oss, "好像还真的是出错了!");OutputDebugInfo(oss, "原来,并没有出错啊");cout << oss.str() << endl;OutputDebugInfo(ofs, "完成输出你好世界!");OutputDebugInfo(cout, "终于不辱使命,即将全身而退。");
}

4. 课堂作业

请到 d2school.com 网站通过作业强化本课所学知识。

这篇关于C++之“流”-第1课.下:实战:最简日志系统的演化的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1010621

相关文章

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

C++中实现调试日志输出

《C++中实现调试日志输出》在C++编程中,调试日志对于定位问题和优化代码至关重要,本文将介绍几种常用的调试日志输出方法,并教你如何在日志中添加时间戳,希望对大家有所帮助... 目录1. 使用 #ifdef _DEBUG 宏2. 加入时间戳:精确到毫秒3.Windows 和 MFC 中的调试日志方法MFC

SpringBoot如何使用TraceId日志链路追踪

《SpringBoot如何使用TraceId日志链路追踪》文章介绍了如何使用TraceId进行日志链路追踪,通过在日志中添加TraceId关键字,可以将同一次业务调用链上的日志串起来,本文通过实例代码... 目录项目场景:实现步骤1、pom.XML 依赖2、整合logback,打印日志,logback-sp