c++11 标准模板(STL)(std::basic_streambuf)(八)

2024-03-06 10:59

本文主要是介绍c++11 标准模板(STL)(std::basic_streambuf)(八),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

定义于头文件 <streambuf>
template<

    class CharT,
    class Traits = std::char_traits<CharT>

> class basic_streambuf;

 类 basic_streambuf 控制字符序列的输入与输出。它包含下列内容并提供到它们的访问:

1) 受控制字符序列,又称为缓冲区,它可含有为输入操作缓冲的输入序列(又称为获取区),和/或为输出操作缓冲的输出序列(又称为放置区)。

2) 关联字符序列,又称作(对于输入)或(对于输出)。它可以是通过 OS API 访问的实体(文件、 TCP 接头、串行端口、其他字符设备),或者可以是能转译成字符源或池的对象( std::vector 、数组、字符串字面量)。

I/O 流对象 std::basic_istream 及 std::basic_ostream ,还有所有导出自它们的对象( std::ofstream 、 std::stringstream 等),都完全以 std::basic_streambuf 实现。

受保护成员函数

放置区

将多个字符写到输出序列

std::basic_streambuf<CharT,Traits>::sputn, 
std::basic_streambuf<CharT,Traits>::xsputn

std::streamsize sputn( const char_type* s, std::streamsize count );

(1)

protected:
virtual std::streamsize xsputn( const char_type* s, std::streamsize count );

(2)

1) 调用最终导出类的 xsputn(s, count)

2) 从首元素为 s 所指向的数组写 count 个字符到输出序列。如同以重复调用 sputc() 写入字符。在写入 count 字符后或调用 sputc() 会返回 Traits::eof() 时写入停止。

若放置区变满( pptr() == epptr() ),则此函数可调用 overflow() ,或以其他未指定手段达成调用 overflow() 的效果。

参数

(无)

返回值

成功写入的字符数。

注意

“以未指定手段达成 overflow() 的效果”容许无中间缓冲的大量 I/O :这是一些 iostream 的实现中, std::ofstream::write 简单地传递指针给 POSIX write() 系统调用的缘由。

 调用示例

#include <iostream>
#include <sstream>int main()
{std::ostringstream s1;std::streamsize sz = s1.rdbuf()->sputn("This is a test", 14);s1 << '\n';std::cout << "The call to sputn() returned " << sz << '\n'<< "The output sequence contains " << s1.str();std::istringstream s2;sz = s2.rdbuf()->sputn("This is a test", 14);std::cout << "The call to sputn() on an input stream returned " << sz << '\n';
}
输出

从放置区写入字符到关联的输出序列

std::basic_streambuf<CharT,Traits>::overflow

virtual int_type overflow( int_type ch = Traits::eof() );

通过保存始于 pbase() 的某个起始字符子序列到输入序列,并更新放置区(若需要),确保放置区有至少一个字符的空间。若 ch 不是 Traits::eof() (即 Traits::eq_int_type(ch, Traits::eof()) != true ),则将它放到放置区或直接保存到输出序列。

函数可以更新 pptrepptrpbase 指针以定义要写入更多数据的位置。失败时,函数确保 pptr() == nullptr 或 pptr() == epptr 。

函数的基类版本不做任何事。允许此函数的导出类版本在耗尽的情况下更新放置区。

参数

ch-要存储于放置区的字符

返回值

成功时返回不等于 Traits::eof() 的未指定值,失败时返回 Traits::eof() 。

此函数的基类版本返回 Traits::eof() 。

注意

sputc() 和 sputn() 在可能上溢的情况( pptr() == nullptr 或 pptr() >= epptr() )下调用此函数。

调用示例

#include <iostream>
#include <array>// 以 std::array 实现的 std::ostream 缓冲区
template<std::size_t SIZE, class CharT = char>
class ArrayedStreamBuffer : public std::basic_streambuf<CharT>
{
public:using Base = std::basic_streambuf<CharT>;using char_type = typename Base::char_type;using int_type = typename Base::int_type;ArrayedStreamBuffer() : buffer_{} // 值初始化 buffer_ 为全零{Base::setp(buffer_.begin(), buffer_.end()); // 设置 std::basic_streambuf// 放置区指针以 'buffer_' 工作}int_type overflow(int_type ch){std::cout << "overflow\n";return Base::overflow(ch);}void print_buffer(){for (const auto& i : buffer_){if (i == 0){std::cout << "NULL";}else{std::cout << i;}std::cout << " ";}std::cout << "\n";}private:std::array<char_type, SIZE> buffer_;
};int main()
{ArrayedStreamBuffer<10> streambuf;std::ostream stream(&streambuf);stream << "hello";streambuf.print_buffer();if (stream.good()){std::cout << "stream is good\n";}stream << "world";streambuf.print_buffer();if (stream.good()){std::cout << "stream is good\n";}stream << "!";streambuf.print_buffer();if (!stream.good()){std::cout << "stream is not good\n";}
}
 输出

返回指向放置区的起始、当前字符和末尾的指针

std::basic_streambuf<CharT,Traits>::pbase, 
std::basic_streambuf<CharT,Traits>::pptr, 
std::basic_streambuf<CharT,Traits>::epptr

char_type* pbase() const;

(1)

char_type* pptr() const;

(2)

char_type* epptr() const;

(3)

返回定义放置区的指针。

1) 返回指向放置区起始(“基”)的指针。

2) 返回指向放置区中当前字符的指针(放置指针)。

3) 返回指向放置区结尾后一位置的指针。

参数

(无)

返回值

1) 指向放置区起始的指针。

2) 指向放置区中当前字符的指针(放置指针)。

3) 指向放置区结尾后一位置的指针。

令输出序列中的下一位置指针前进

std::basic_streambuf<CharT,Traits>::gbump

void gbump( int count );

 跳过获取区中的 count 个字符。通过令获取指针前进 count 个字符。不为下溢做检查。

参数

count-要跳过的字符数

返回值

(无)

注意

因为此函数接收 int ,故它无法操纵大于 std::numeric_limits<int>::max() 字符的缓冲区( LWG 255 )。

重定位输出序列的起始、下一位置和终止指针

std::basic_streambuf<CharT,Traits>::setp

void setp( char_type* pbeg, char_type* pend );

设置定义放置区的指针值。特别是调用后 pbase() == pbeg 、 pptr() == pbeg 、 epptr() == pend 。

参数

pbeg-指向放置区新起始的指针
pend-指向放置区新结尾的指针

返回值

(无)

这篇关于c++11 标准模板(STL)(std::basic_streambuf)(八)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

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

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

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

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

C++ vector的常见用法超详细讲解

《C++vector的常见用法超详细讲解》:本文主要介绍C++vector的常见用法,包括C++中vector容器的定义、初始化方法、访问元素、常用函数及其时间复杂度,通过代码介绍的非常详细,... 目录1、vector的定义2、vector常用初始化方法1、使编程用花括号直接赋值2、使用圆括号赋值3、ve

如何高效移除C++关联容器中的元素

《如何高效移除C++关联容器中的元素》关联容器和顺序容器有着很大不同,关联容器中的元素是按照关键字来保存和访问的,而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的,本文介绍了如何高效移除C+... 目录一、简介二、移除给定位置的元素三、移除与特定键值等价的元素四、移除满足特android定条件的元

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下:

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat