- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
考虑两个刷新缓冲区的函数:
fflush()
sync()
我怎么知道什么时候需要调用其中一个?
我知道将 '\n'
添加到 printf()
将刷新输出缓冲区,但如果字符串不包含此类字符, 我什么时候可以跳过这个调用,什么时候不能(多线程系统?)?
同样适用于sync
。我有一个将文件保存到文件系统中的功能(保存是通过一系列系统调用完成的),而且在特定情况下似乎没有调用 sync
文件不会保存
不幸的是,我目前没有关于该案例的所有详细信息 [我所知道的是文件已保存,之后会立即关闭电源(不知 Prop 体多久) 并且文件在重启后不存在]。在我运行的所有测试中,文件都已正确保存。
那么,我如何确定系统何时刷新文件数据/元数据缓冲区以及何时不刷新,我需要显式调用 sync()
?
引用 man (未指定何时需要显式调用):
sync, syncfs - commit buffer cache to disk
sync() causes all buffered modifications to file metadata and data to be written to the underlying file systems.
fflush - flush a stream
For output streams, fflush() forces a write of all user-space buffered data for the given output or update stream via the stream's underlying write function. For input streams, fflush() discards any buffered data that has been fetched from the underlying file, but has not been consumed by the application. The open status of the stream is unaffected.
附带问题:
The 1st comment on this answer展示了一种通过使用 setbuf(stdout, NULL);
来禁用 stdout
缓冲的方法。是否有类似 sync
的东西(为此使用什么缓冲区?)?
最佳答案
同步()
您很少需要调用 sync()
.当你这样做时,你有一些重要的东西必须尽快记录在磁盘上。但是,sync()
将在内核内存中安排写入缓冲区后返回,而不是在它们被写入之后返回,因此您不会知道它们实际上已经被写入——所以它不是完全可靠。如果您需要更多地控制文件的写入,请查看 open()
的 O_SYNC
、O_DSYNC
、O_RSYNC
标志。 .您可能必须使用 fcntl()
和 fileno()
如果您使用文件流而不是文件描述符,请设置这些标志。
两个注意事项:
sync()
不会将您的进程(或任何其他进程)的缓冲区写入内核缓冲池;它与 fflush()
完全无关。sync()
影响系统上所有进程写入的所有数据——如果您的应用程序经常使用它,您可能会变得不受欢迎;它颠覆了内核缓存数据的良好工作。fflush()
fflush()
函数确保数据已从应用程序的缓冲区写入内核缓冲池(对于单个文件,或者对于所有输出文件,如果您使用 fflush(0)
或 fflush(NULL)
)。它不直接影响其他进程。同样,当您需要确信挂起的输出已发送到内核以进行后续传输时,您可以使用它。您可以使用它的一个地方是在您希望提示出现的输入操作之前,即使它最后没有换行符。否则,您不经常使用它,但您可以在任何时候使用它来确保数据已发送到内核进行写入。如果您正在调试并且您的程序崩溃了,少量的 fflush()
语句可以确保在崩溃之前写入挂起的输出。这有助于更准确地揭示问题所在(但使用调试器也可以)。
请注意,设置无缓冲输出(setbuf(stdout, NULL)
或 setvbuf(stdout, NULL, _IONBF, 0)
)意味着所有输出“立即”发生。这不一定有利于性能。您有时会使用它,但很少使用。
关于c - 如何知道何时需要缓冲区刷新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52601811/
我正在尝试用 C 语言编写一个使用 gstreamer 的 GTK+ 应用程序。 GTK+ 需要 gtk_main() 来执行。 gstreamer 需要 g_main_loop_run() 来执行。
我已经使用 apt-get 安装了 opencv。我得到了以下版本的opencv2,它工作正常: rover@rover_pi:/usr/lib/arm-linux-gnueabihf $ pytho
我有一个看起来像这样的 View 层次结构(基于其他答案和 Apple 的使用 UIScrollView 的高级 AutoLayout 指南): ScrollView 所需的2 个步骤是: 为 Scr
我尝试安装 udev。 udev 在 ./configure 期间给我一个错误 --exists: command not found configure: error: pkg-config and
我正在使用 SQLite 3。我有一个表,forums,有 150 行,还有一个表,posts,有大约 440 万行。每个帖子都属于一个论坛。 我想从每个论坛中选择最新帖子的时间戳。如果我使用 SEL
使用 go 和以下包: github.com/julienschmidt/httprouter github.com/shwoodard/jsonapi gopkg.in/mgo.v2/bson
The database仅包含 2 个表: 钱包(100 万行) 事务(1500 万行) CockroachDB 19.2.6 在 3 台 Ubuntu 机器上运行 每个 2vCPU 每个 8GB R
我很难理解为什么在下面的代码中直接调用 std::swap() 会导致编译错误,而使用 std::iter_swap 编译却没有任何错误. 来自 iter_swap() versus swap() -
我有一个非常简单的 SELECT *用 WHERE NOT EXISTS 查询条款。 SELECT * FROM "BMAN_TP3"."TT_SPLDR_55E63A28_59358" SELECT
我试图按部分组织我的 .css 文件,我需要从任何文件访问文件组中的任何类。在 Less 中,我可以毫无问题地创建一个包含所有文件导入的主文件,并且每个文件都导入主文件,但在 Sass 中,我收到一个
Microsoft.AspNet.SignalR.Redis 和 StackExchange.Redis.Extensions.Core 在同一个项目中使用。前者需要StackExchange.Red
这个问题在这里已经有了答案: Updating from Rails 4.0 to 4.1 gives sass-rails railties version conflicts (4 个答案) 关
我们有一些使用 Azure DevOps 发布管道部署到的现场服务器。我们已经使用这些发布管道几个月了,没有出现任何问题。今天,我们在下载该项目的工件时开始出现身份验证错误。 部署组中的节点显示在线,
Tip: instead of creating indexes here, run queries in your code – if you're missing any indexes, you
你能解释一下 Elm 下一个声明中的意思吗? (=>) = (,) 我在 Elm architecture tutorial 的例子中找到了它 最佳答案 这是中缀符号。实际上,这定义了一个函数 (=>
我需要一个 .NET 程序集查看器,它可以显示低级详细信息,例如元数据表内容等。 最佳答案 ildasm 是 IL 反汇编程序,具有低级托管元数据 token 信息。安装 Visual Studio
我有两个列表要在 Excel 中进行比较。这是一个很长的列表,我需要一个 excel 函数或 vba 代码来执行此操作。我已经没有想法了,因此转向你: **Old List** A
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想要改善这个问题吗?更新问题,以便将其作为on-topi
我正在学习 xml 和 xml 处理。我无法很好地理解命名空间的存在。 我了解到命名空间帮助我们在 xml 中分离相同命名的元素。我们不能通过具有相同名称的属性来区分元素吗?为什么命名空间很重要或需要
我搜索了 Azure 文档、各种社区论坛和 google,但没有找到关于需要在公司防火墙上打开哪些端口以允许 Azure 所有组件(blob、sql、compute、bus、publish)的简洁声明
我是一名优秀的程序员,十分优秀!