C++ 头文件系列(streambuf)
1. 简介
该头文件定义了basic_streambuf模版,从字面上看是作为流缓冲区之用。
2. basic_streambuf模版
The class template basic_stream< charT, traits > serves as an abstract base class for deriving various stream buffers whose objects each control two character sequences:
—— a character input sequence;
—— a character output sequence.
上面这段话(摘自C++14草案)的大概意思是说:basic_streambuf模版的目的是作为各种各样的 派生流缓冲区 的虚基类, 这些流缓冲区控制两个字符序列----一个输入一个输出。
2.1 控制 输入/输出流
streambuf不直接直接控制输入输出流,而是通过两个数组的六个指针来间接控制:

basc_streambuf模版分别为每一个流指针组提供了5个函数。
2.1.1 输入流指针函数
- eback : 返回输入流的首指针。
- gptr : 返回输入流的当前指针。
- egptr : 返回输入流的尾指针。
- gbump : 将当前指针前进n步。
- setg : 设置三个输入流指针。
2.1.2 输出流指针函数
- pbase : 返回输出流的首指针。
- pptr : 返回输出流的当前指针。
- epptr : 返回输出流的尾指针。
- pbump : 将当前指针步进n步。
- setp : 设置三个输出流指针。
2.2 virtual函数
这些虚函数为protected,旨在为派生的类提供机会来自定义一些共有的行为。 注意,这些虚函数的定义很抽象(作为基类抽象函数),并且在基类中都 定义为空。
2.2.1 本地化
- imbue : “注入”本地化对象。
2.2.2 缓冲区管理和定位
- setbuf : 设置缓冲区。
- seekoff、seekpos : 更改缓冲区中当前字符位置。
- sync : 同步缓冲区与控制字符流。
2.2.3 输入函数
- showmanyc : 返回输入字符流中当前大概可获得的字符数。
- xsgetn : 从输入字符流中获取n个字符。
- underflow : 从输入字符流获取当前字符,不改变当前位置。(具体作用不是很明白,有待探究)
- uflow : 从输入字符流获取当前字符,步进当前位置,默认实现为调用underflow()。
- pbackfail : 将给定字符放回输入字符流。 该函数仅当没有放回位置或者放回的字符与缓冲区中的字符不一致时才被调用,故后缀fail。
2.2.4 输出函数
- xsputn : 将n个字符写到输出字符流。
- overflow : 将字符写到输出字符流。
2.3 public函数
2.3.1 本地化
- pubimbue : 调用虚函数imbue。
- getloc : 返回当前本地化对象(locale)。
2.3.2 缓冲区管理和定位
- pubsetbuf :调用虚函数setbuf。
- pubseekoff : 调用虚函数seekoff。
- pubsync : 调用虚函数sync。
2.3.3 输入函数
- in_avail : 如果读取位置可获得,返回当前可获得的字符数;否则,调用虚函数showmanyc。
- snextc : 步进当前位置,并且返回当前字符。
- sbumpc : 如果输入流读取位置可获得,获取当前字符,并且步进当前位置; 否则,调用虚函数uflow。
- sgetc : 如果输入流读取位置可获得,返回当前字符; 否则,调用虚函数underflow。
- sgetn : 获取n个字符,调用虚函数xsgetn。
- sputbackc : 放回给定字符,若无法放回则调用虚函数pbackfail。
- sungetc : 递减当前位置,并返回当前字符。
2.3.4 输出函数
- sputc : 如果输出流写位置可获得,输出一个字符; 否则,调用虚函数overflow。
- sputn : 输出n个字符,调用虚函数xsputn。
3 typedefs
typedef basic_streambuf<char> streambuf;typedef basic_streambuf<wchar_t> wstreambuf;
C++ 头文件系列(streambuf)的更多相关文章
- C++ 头文件系列(array)
注意,该头文件仅在C++11中标准才开始出现. 简介 与语言内置的数组一样, array类模版支持几乎所有内置数组包含的特性: 顺序的(sequence) 内存连续的(contiguous stora ...
- C++ 头文件系列(queue)
简介 这个头文件定义了两个跟队列有关的类----quque.priority_queue,分别实现的是队列 和 优先队列这两个概念. 但是与这两个类模版与其它类模版(vector.array等)最大的 ...
- C++ 头文件系列(stack)
简介 该头文件只含有一个类模版stack, 它实现栈的概念,是一个容器适配器(说实话,在写这篇随笔之前我都不知道有这么个类模版). 栈 栈只有一个重要的特性: LIFO(last-in first-o ...
- C++ 头文件系列(vector)
简介 vector头文件包含vector的类模版以及该模版的显示特化版本vector< bool >. vector是C++容器库中非常通用的一种容器,如果你不知道该决定使用哪一种容器,或 ...
- C++ 头文件系列(map)
简介 该头文件包含两个概念相似的容器----map.multimap. 而这两个容器反映的概念就是 映射. 这两个容器 相同 的属性有: 关联性 映射 动态增长 键(Key)唯一性 这两个不相同的属性 ...
- C++ 头文件系列(unordered_map、unordered_set)
简介 很明显,这两个头文件分别是map.set头文件对应的unordered版本. 所以它们有一个重要的性质就是: 乱序 如何乱序 这个unorder暗示着,这两个头文件中类的底层实现----Hash ...
- C++ 头文件系列(iterator)
简介 该头文件围绕迭代器展开,定义了一系列与迭代器有关的概念,但最最最重要的一点就是----它和其它容器一起实现了C++容器的Iterator设计模式. Iterators are a general ...
- C++ 头文件系列 (algorithm)
简介 algorithm头文件是C++的标准算法库,它主要应用在容器上. 因为所有的算法都是通过迭代器进行操作的,所以算法的运算实际上是和具体的数据结构相分离的 ,也就是说,具有低耦合性. 因此,任何 ...
- C++ 头文件系列 (bitset)
简介 该头文件有关位集,实际上是vector 位 位本质上对应bool的概念,只有0或1,true或false两种对立的值. 但很可惜,字节才是机器上最小的存储单元,所以bool基本上是由一个字节大小 ...
随机推荐
- iOS 之UICollectionView 之原理介绍
0. 简介 参考:支持重排的iOS9 UICollectionView 参考:http://www.cnblogs.com/langtianya/p/3902801.html 参考:http://ww ...
- 2.4 easyui - panel的使用
<div id="p" class="easyui-panel" title="My Panel" style ...
- iOS Socket第三方开源类库 ----AsyncSocket 分类: ios相关 ios技术 2015-03-11 22:14 59人阅读 评论(0) 收藏
假如你也是一个java程序员,而你又不是很懂Socket. 下面我的这篇文章也许能帮助你一些. http://xiva.iteye.com/blog/993336 首先我们写好上面文章中的server ...
- PopupWindow的基本使用
1>写好布局 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:an ...
- ul中li分列显示
让ul中li分列显示,用li显示两列如下(要显视多列的自己想办法,哈哈): 2列 <ul> <li style="display:block;float:left;widt ...
- php刷新当前页面
echo "<script language=JavaScript> location.replace(location.href);</script>"; ...
- xml文档PHP查询代码(学习使用)
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" " http://www.w3.org ...
- 解析 png 图片的十六进制字符流
uses pngimage; {从 png 图片到十六进制字符串} function Png2Hex(png: TPngImage): string; var stream: TMemoryStrea ...
- delphi 获得memo,Richedit焦点所在行
procedure TForm1.Button1Click(Sender: TObject); var i:Integer; begin i:=SendMessage(Richedit1.handle ...
- 在Cocos2d-x中实现较为真实的云彩效果
[前言] 这个效果是公司里上一个项目中用到的.因为项目已经死掉了,并且效果是我自己实现的,与其连着项目工程一起删掉,不如所以共产主义一下给大家作参考. 使用版本:cocos 2d-x 3.6(适用于所 ...