C++ Primer 5th笔记(chap 17 标准库特殊设施)流随机访问

2024-03-28 08:32

本文主要是介绍C++ Primer 5th笔记(chap 17 标准库特殊设施)流随机访问,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 流类型通常都支持对流中数据的随机访问。

可以重定位流, 使之跳过一些数据, 首先读取最后一行, 然后读取第一行, 依此类推。

1.1 标准厍提供了一对函数, 来定位( seek )到流中给定的位置, 以及告诉( tell) 我们当前位置

  • seek函数:将标记 seek 到一个给定位置来重定位它;
  • tell 函数:tell 我们标记的当前位置。

标准库实际上定义了两对 seek 和 tell 函数:

  • g 版本表示我们正在“ 获得”( 读取) 数据
  • p 版本表示我们正在“ 放置”( 写入) 数据

只适用于fstream和sstream。

操作解释
tellg()tellp 返回一个输入流中(tellg)或输出流中(tellp)标记的当前位置。
seekg(pos)seekp(pos) 在一个输入流或输出流中将标记重定位到给定的绝对地址。pos通常是一个当前teelg或tellp返回的值。
seekp(off, from) seekg(off, from)在一个输入流或输出流中将标记定位到from之前或之后off个字符,from可以是下列值之一:beg,偏移量相对于流开始位置;cur,偏移量相对于流当前位置;end,偏移量相对于流结尾位置。

1.2 只有一个标记

标准库区分 seek 和 tell 函数的“ 放置” 和“ 获得” 版本这一特性可能会导致误解。
即使标准库进行了区分, 但它在一个流中只维护单一的标记—并不存在独立的读标记和写标记

由于只有单一的标记, 因此只要我们在读写操作间切换, 就必须进行 seek 操作来重1定位标记。 .

1.3 重定位标记

seek 函数有两个版本: 一个移动到文件中的“ 绝对” 地址: 另一个移动到一个给定位置的指定偏移量:

//将标记移动到一个固定位置
seekg (new_position); / / 将读标记移动到指定的 pos_type 类型的位置
seekp (new_position); / / 将写标记移动到指定的 pos_type 类型的位置
/ / 移动到给定起始点之前或之后指定的偏移位置
seekg (offset, from); / / 将读标记移动到距 from 偏移量为 offset 的位置
seekp (offset, from); / / 将写标记移动到距 from 偏移量为 of fset 的位置
  • pos_type表示一个文件位置
  • off_type 表示距当前位置的一个偏移量。
    一个 off_type 类型的值可以是正的也可以是负品, 即可以在文件中向前移动或向后移动。

1.4 访问标记

函数 tellg 和 tellp 返回一个pos_type表示流的当前位置。tell 函数通常用来记住一个位置, 以便稍后再定位回来

ostringstream::writeStr;// 输出 stringstream
ostringstream::pos_type mark = writeStr.tellp ( );
// ...
if (cancelEntry)
/ / 回到刚才记住的位置
writeStr.seekp (mark);/ / 以读写方式打开文件, 并定位到文件尾
fstream inOut("test_2.txt", fstream::ate|fstream::in|fstream::out);if(!inOut){return EXIT_FAILURE;}/ / inOut 以 ate 模式打开, 因此一开始就定义到其文件尾auto end_mark = inOut.tellg();//记住原文件尾位置inOut.seekg(0,fstream::beg);/ / 重定位到文件开始size_t cnt = 0;/ / 字节数累加器string line;/ / 保存输入中的每行while(inOut&&inOut.tellg() != end_mark&&getline(inOut,line)){/ / 继续读取的条件: 还未遇到错误且还在读取原数据/ / 且还可获取一行输入cnt += line.size()+1;/ /1表示换行符cout << line.size() << endl;auto mark = inOut.tellg();/ / 记住读取位置inOut.seekp(0,fstream::end);II 将写标记移动到文件尾inOut << cnt;/ / 输出累计的长度
/ / 如果不是最后一行, 打印一个分隔符if(mark != end_mark)inOut << " ";inOut.seekg(mark);/ / 恢复读位置}inOut.seekp(0,fstream::end);

原始文件:

abed
efg
hi
j

修改过的文件:

abed
efg
hi
j5
9 12 14

这篇关于C++ Primer 5th笔记(chap 17 标准库特殊设施)流随机访问的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

Javascript访问Promise对象返回值的操作方法

《Javascript访问Promise对象返回值的操作方法》这篇文章介绍了如何在JavaScript中使用Promise对象来处理异步操作,通过使用fetch()方法和Promise对象,我们可以从... 目录在Javascript中,什么是Promise1- then() 链式操作2- 在之后的代码中使

基于Python实现一个PDF特殊字体提取工具

《基于Python实现一个PDF特殊字体提取工具》在PDF文档处理场景中,我们常常需要针对特定格式的文本内容进行提取分析,本文介绍的PDF特殊字体提取器是一款基于Python开发的桌面应用程序感兴趣的... 目录一、应用背景与功能概述二、技术架构与核心组件2.1 技术选型2.2 系统架构三、核心功能实现解析

C++ Primer 标准库vector示例详解

《C++Primer标准库vector示例详解》该文章主要介绍了C++标准库中的vector类型,包括其定义、初始化、成员函数以及常见操作,文章详细解释了如何使用vector来存储和操作对象集合,... 目录3.3标准库Vector定义和初始化vector对象通列表初始化vector对象创建指定数量的元素值

如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件

《如何使用Docker部署FTP和Nginx并通过HTTP访问FTP里的文件》本文介绍了如何使用Docker部署FTP服务器和Nginx,并通过HTTP访问FTP中的文件,通过将FTP数据目录挂载到N... 目录docker部署FTP和Nginx并通过HTTP访问FTP里的文件1. 部署 FTP 服务器 (

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

C++一个数组赋值给另一个数组方式

《C++一个数组赋值给另一个数组方式》文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方... 目录C++一个数组赋值给另一个数组循环遍历赋值使用标准库中的函数 std::copy 或 std::

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定