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)的更多相关文章

  1. C++ 头文件系列(array)

    注意,该头文件仅在C++11中标准才开始出现. 简介 与语言内置的数组一样, array类模版支持几乎所有内置数组包含的特性: 顺序的(sequence) 内存连续的(contiguous stora ...

  2. C++ 头文件系列(queue)

    简介 这个头文件定义了两个跟队列有关的类----quque.priority_queue,分别实现的是队列 和 优先队列这两个概念. 但是与这两个类模版与其它类模版(vector.array等)最大的 ...

  3. C++ 头文件系列(stack)

    简介 该头文件只含有一个类模版stack, 它实现栈的概念,是一个容器适配器(说实话,在写这篇随笔之前我都不知道有这么个类模版). 栈 栈只有一个重要的特性: LIFO(last-in first-o ...

  4. C++ 头文件系列(vector)

    简介 vector头文件包含vector的类模版以及该模版的显示特化版本vector< bool >. vector是C++容器库中非常通用的一种容器,如果你不知道该决定使用哪一种容器,或 ...

  5. C++ 头文件系列(map)

    简介 该头文件包含两个概念相似的容器----map.multimap. 而这两个容器反映的概念就是 映射. 这两个容器 相同 的属性有: 关联性 映射 动态增长 键(Key)唯一性 这两个不相同的属性 ...

  6. C++ 头文件系列(unordered_map、unordered_set)

    简介 很明显,这两个头文件分别是map.set头文件对应的unordered版本. 所以它们有一个重要的性质就是: 乱序 如何乱序 这个unorder暗示着,这两个头文件中类的底层实现----Hash ...

  7. C++ 头文件系列(iterator)

    简介 该头文件围绕迭代器展开,定义了一系列与迭代器有关的概念,但最最最重要的一点就是----它和其它容器一起实现了C++容器的Iterator设计模式. Iterators are a general ...

  8. C++ 头文件系列 (algorithm)

    简介 algorithm头文件是C++的标准算法库,它主要应用在容器上. 因为所有的算法都是通过迭代器进行操作的,所以算法的运算实际上是和具体的数据结构相分离的 ,也就是说,具有低耦合性. 因此,任何 ...

  9. C++ 头文件系列 (bitset)

    简介 该头文件有关位集,实际上是vector 位 位本质上对应bool的概念,只有0或1,true或false两种对立的值. 但很可惜,字节才是机器上最小的存储单元,所以bool基本上是由一个字节大小 ...

随机推荐

  1. 10天学会phpWeChat——第八天:Form类,丰富表单提交的字段类型

    通过前面七讲的系列教程,我们完成了一个包含后台并自适应PC+h5移动端的文章管理模块. 在实际的生产环境中,文章投稿.商品上传等操作并不会简单局限于一个text和textarea组成的表单.在实际中, ...

  2. win7下sublime text3 安装Emmet的pyv8

    1.通过快捷键 ctrl+` 或者 View > Show Console 菜单打开控制台 2.适用于 Sublime Text 3: import urllib.request,os;pf=' ...

  3. ZOJ 1025 Wooden Sticks

    题目大意:有n个木棍,分别具有长度li和重量wi.对于木棍s1和s2,若l1<=l2且w1<=w2,则s1.s2可构成单调递增序列.求n个木棍中这样序列的个数. 最先的想法是,先排序,然后 ...

  4. webpack之代码分离

    https://robertknight.github.io/posts/webpack-dll-plugins/ webpack一般会把一个文件里import/require的文件都会打包在一起,最 ...

  5. 重新回顾JSP

    由于个人喜好,觉得自己需要学习一下,服务端的语言.JSP之前学过,不够许久未用了. http://www.w3cschool.cc/jsp/jsp-intro.html 1.Java代码片段使用< ...

  6. --@angularjs-- $location.path('/login')-$location服务用法示例

    $httpProvider interceptor .factory('auth403', ['$rootScope', '$q', '$location', function auth403($ro ...

  7. java 数据设置和显示

    1. 首先设置ModelAndView 的值 @Override public ModelAndView handleRequest(HttpServletRequest arg0, HttpServ ...

  8. pureMVC简单示例及其原理讲解一(开篇)

    pureMVC是一个MVC框架,皆在最大限度的减少MVC间的耦合性.本人刚刚接触pureMVC时感到一头雾水,不知从何入手,也不知道从何学习.好在本人有耐性且能看懂英文技术文档,面向对象的编程能力也比 ...

  9. [TPYBoard-Micropython教程之1] 运行第一个脚本——点亮LED

    转载请注明:@小五义http://www.cnblogs.com/xiaowuyiQQ群:64770604 会python就能做硬件! 一.TPYBoard V102开发板 TPYBoard V102 ...

  10. 浅谈Socket长连+多线程[原创,欢迎指点]

    前戏 [PS:原文手打,转载说明出处] [PS:博主自认为适用于云平台设备管控,且适用于IM主控] 好久没来了,13年时还想着多写一些博客,这都17年过年,年前也写一写Scoket+多线程,不足之处, ...