【C++】继承streambuf,对cout进行重定向

2024-03-06 10:59

本文主要是介绍【C++】继承streambuf,对cout进行重定向,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

旧内容已过时

下面的东西不用看了,看了浪费时间,对开发作用不大。(不想改单纯是因为已经打算不用CSDN了,因此文章内容不再维护







又来水了




简单说明

先形容一下要实现的功能:

使用cout语句,但输出在别的地方(可能是文件,可能是管道,也可能是其他奇奇怪怪的东西)

实现上面的功能意味着要想办法控制cout缓冲区清空时的操作,毕竟我还是挺想要cout<<endl或者cout<<flush自带的缓冲区刷新功能的,而这功能让我摸了老半天,(不知道我说的啥的话可以看看下面的【运行结果】),摸完之后爽玩几天的兰斯10然后才开始搞正事。

难点不多,所以很水。




关键词:

cout.rdbuf:这函数将cout重定向到其他的字节流
streambuf::sync:cout.flush()最终会调用到的函数(cout<<endl也会触发/调用cout.flush())。这是我翻源码èn是给找到的…




图文说明:




代码:

#include<iostream>
#include<string>
using namespace std;//继承streambuf:https://www.cnblogs.com/wangshaowei/p/11905831.html
class XJ_Streambuf :public streambuf {
private:enum { __size = 10 };//缓冲区大小,一般建议设置1024,毕竟1024字节也就1MB大小,内存不痛不痒char __buffer[__size + 1] = { 0 };//缓冲区
public:XJ_Streambuf() {setbuf(__buffer, __size);}protected://以下全是streambuf类的virtual函数的重写int_type overflow(int_type c)override {//缓冲区溢出时要调用sync清空缓冲区printf("/");sync();//清空缓冲区sputn((char*)&c, 1);//把溢出的字符c塞回到缓冲区return c;}int __CLR_OR_THIS_CALL sync()override {//这个是关键,在刷新缓冲区时将被被动调用,表现为输出缓冲区内容+清空缓冲区printf(__buffer);setbuf(__buffer, __size);printf(".");return 0;}streambuf* setbuf(char* s, streamsize n)override {//重置缓冲区memset(s, 0, __size);setp(s, s, s + n);setg(s, s, s + n);return this;}
};int main() {char str_P[32] = { 0 };//搞份字符串char str_Q[32] = { 0 };memset(str_P, 'P', 15);memset(str_Q, 'Q', 20);XJ_Streambuf buf;//字符缓冲区cout.rdbuf(&buf);//cout重定向cout << str_P << str_Q << endl;return 0;
}



参考内容

cout重定向:https://blog.csdn.net/qq_34039018/article/details/120136038
streambuf继承:https://www.cnblogs.com/wangshaowei/p/11905831.html


其他链接

CSDN(本博客发布于CSDN,附上这条链接是防盗):https://blog.csdn.net/weixin_44733774/article/details/127201133
github(都贴源码了就没必要翻去看github了吧…):https://github.com/Ls-Jan/CPP_streambuf

这篇关于【C++】继承streambuf,对cout进行重定向的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

使用zabbix进行监控网络设备流量

《使用zabbix进行监控网络设备流量》这篇文章主要为大家详细介绍了如何使用zabbix进行监控网络设备流量,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录安装zabbix配置ENSP环境配置zabbix实行监控交换机测试一台liunx服务器,这里使用的为Ubuntu22.04(

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

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

在Pandas中进行数据重命名的方法示例

《在Pandas中进行数据重命名的方法示例》Pandas作为Python中最流行的数据处理库,提供了强大的数据操作功能,其中数据重命名是常见且基础的操作之一,本文将通过简洁明了的讲解和丰富的代码示例,... 目录一、引言二、Pandas rename方法简介三、列名重命名3.1 使用字典进行列名重命名3.编

python安装完成后可以进行的后续步骤和注意事项小结

《python安装完成后可以进行的后续步骤和注意事项小结》本文详细介绍了安装Python3后的后续步骤,包括验证安装、配置环境、安装包、创建和运行脚本,以及使用虚拟环境,还强调了注意事项,如系统更新、... 目录验证安装配置环境(可选)安装python包创建和运行Python脚本虚拟环境(可选)注意事项安装

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

深入理解C++ 空类大小

《深入理解C++空类大小》本文主要介绍了C++空类大小,规定空类大小为1字节,主要是为了保证对象的唯一性和可区分性,满足数组元素地址连续的要求,下面就来了解一下... 目录1. 保证对象的唯一性和可区分性2. 满足数组元素地址连续的要求3. 与C++的对象模型和内存管理机制相适配查看类对象内存在C++中,规