- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有以下代码片段:
ofile.open("New1.dat",ios::app|ios::binary|ios::ate);
long bytes = ofile.tellp()/sizeof(t);
cout<<ofile.tellp()<<endl; //line 1
t.input(bytes);
ofile.write((char *)&t,sizeof(t));
ofile.close();
当我删除 ios::app
或 ios::ate
时,第 1 行
的输出为 0,但是只有当两者都存在时他们在一起,他们给出了正确的文件位置。为什么会这样?附言我知道 ios::app 和 ios::ate 之间的区别。
提前致谢!
最佳答案
来自 std::ios::openmode (C++11 第 27.5.3.1.4 节)
std::ios::app
表示在每次写入之前寻找到流的末尾。所以流可能不会在任何写操作之前结束。无论指针在哪里(0
或其他地方)写入总是在最后完成。 (隐式寻道在每次写操作前结束)
另一方面,std::ios::ate
意味着在打开后立即寻找到流的末尾,从而保证返回文件的大小。
进一步阅读:C++ Filehandling: Difference between ios:app and ios:ate?
关于c++ - 为什么 tellp() 为 ios::app 返回 0 而不是为 ios::ate?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28853546/
我认为stringstream的长度是由 block 计算的。这意味着它有多少 block ,它有多长。 block 被'\t''\s分割' '\n'. 例如,stringstream = '23\t
在下面的片段中,我计算了一个文件的位置,以便写入。 然后我尝试打印那个位置。它返回了一个不正确的值; printf("nXBlocks: %i nYBlocks: %i posX: %i, posY:
boost 文件锁定(可共享和作用域 file_locks)的一般策略,以及我认为一般的文件锁定,是这样的: 打开 锁 对文件内容进行操作 解锁 关闭文件 但是,我将打开文件进行追加,并想调用 tel
我正在试验 C++ 中的文件指针。在下面的代码中,获得的结果是 0、30、10 和 12。这意味着如果我们执行 seekp(),tellp() 不会在追加模式下给出正确的结果。我期待 tellp(
我正在开发一个记录器,它有一条继承 std::stringstream 的消息. 当我想打印出消息时,我调用了一个接受消息的函数 const : void logger::log_message(me
我想在一个紧密的循环中每秒调用它数千次。通话费贵吗?我正在使用 Windows Visual C++。 最佳答案 这是一个老问题,但我还是会回答,以防有其他人在寻找答案。 所以我们有一个日志库,它使用
与 fstream file("test.txt",ios_base::in | ios_base::out | ios_base::binary); tellp 和 tellg 对于 file 是否
我正在尝试使用 filtering_streams 将某些对象的序列化压缩到 array_sink 或类似设备中,然后我可以确定压缩输出的长度并将其复制到另一个流,比如文件。但是,在 filterin
每当我想将位置设置为 X tellp return -1 时,fstream 中的 seekp() 有一个小问题。 代码: fstream file("Riot.exe", ios::in | ios
我正在编写一个在文件中维护 linked_list 的程序。因此,我通过使用 tellp()/tellg() 遍历文件并将其添加到特定的长整数(可以看作是偏移量)以到达新位置。 一个简单的例子是
我对在空 ostringstream 上调用 tellp 的标准行为有疑问。我有一个函数 foo,它首先调用 tellp: void foo(std::ostream& os) { std::
#include #include int main() { const char* fileName = "out1"; std::ofstream fs1(fileName);
是否有与 C++ ostream::tellp 的 StreamWriter 等效的 C#?我正在将一些旧的 C++ 代码移植到 C#,但客户仍然想继续使用软盘(阅读:旧设备),所以我需要找到一种方法
我想为 C++ 文本输出流提供类似选项卡的功能。该功能应该允许我说“注意这个位置”,然后允许多次插入操作,最后允许我说“添加足够的填充字符,以便结束 N 个字符超过最初注意到的位置” . 标准的 io
为什么 tellg() 和 tellp() 总是在一起?我们如何将它们彼此分开? 最佳答案 他们没有。 一个表示“获取”游标在输入流中的位置;另一个指示“放置”光标在输出流中的位置。 它们相似但没有内
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我正在尝试将一些数据附加到文件中,但在某些情况下想要从末尾向后跳一点以覆盖文件的尾端。但是,seekp( pos ) 和 seekp( offset, relative ) 对我都没有任何影响(除了在
通过前面章节的学习我们知道,无论是使用 cout 输出普通数据,用 cout.put() 输出指定字符,还是用 cout.write() 输出指定字符串,数据都会先放到输出流缓冲区,待缓冲区刷新,数据
对于数据记录应用程序,我必须将一些(以前)未知大小的 block 写入文件。为了方便阅读,我想添加有关 block 大小的信息。与 RAM 的大小相比,数据可能很大,因此在 RAM 中使用缓冲区的解决
我在 Windows 10 和 Linux 中使用 Qt 5.7 执行相同的代码,但它只适用于 Linux。我正在尝试确定我刚刚创建的 Ostream IOstream 的大小,因此它应该是空的。在
我是一名优秀的程序员,十分优秀!