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++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Java程序进程起来了但是不打印日志的原因分析

《Java程序进程起来了但是不打印日志的原因分析》:本文主要介绍Java程序进程起来了但是不打印日志的原因分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java程序进程起来了但是不打印日志的原因1、日志配置问题2、日志文件权限问题3、日志文件路径问题4、程序

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

在Spring Boot中浅尝内存泄漏的实战记录

《在SpringBoot中浅尝内存泄漏的实战记录》本文给大家分享在SpringBoot中浅尝内存泄漏的实战记录,结合实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录使用静态集合持有对象引用,阻止GC回收关键点:可执行代码:验证:1,运行程序(启动时添加JVM参数限制堆大小):2,访问 htt

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要