fsync和write的区别,fsync函数作用

2025-05-15 16:56:16 函数指令 嘉兴
  1. fsync和write的区别
  2. 为什么关闭一个缓冲区输出流之前应使用flush方法

fsync和write的区别

write:数据库会将buffer中的脏页根据写入策略将老化的脏页面写到OS,OS再根据自己的调度算法将脏页写入硬盘。

fsync:数据库直接调用OS的fsync函数,直接写入硬盘。

fsync和write的区别,fsync函数作用

write

ssize_t write(int fd, const void *buf, size_t count);

将数据写到文件中. 注意, 如果文件是保存在硬盘中, write() 函数调用返回之后, 并不表示数据已经写入到硬盘中, 这时如果掉电, 数据可能会丢失.

fsync

fsync和write的区别,fsync函数作用

int fsync(int fd);

程序调用本函数, 通知内核把数据写到硬盘(file)中. 比如, 你开发一个数据库软件, 就需要这样的函数, 否则掉电或者系统崩溃时便会丢失数据.

为什么关闭一个缓冲区输出流之前应使用flush方法

首先 解释下这个flush的作用
这个是java.io.OutputStream的 空实现(java.io.FileOutputStream使用的是java.io.OutputStream的实现 java.net.SocketOutputStream也是一样)

这个是java.io.BufferedOutputStream的

为了防止过于频繁的写操作 所以Java提供了一个java.io.BufferedOutputStream类 内部持有一个缓冲区 默认不直接将数据写到硬盘上 而是存到缓冲区中 直到一定条件后触发(就是调用上面的flushBuffer()了) 也可以强制通过flush()方法提前触发

所以当你认为你完成了某一个比较重要的操作的时候 最好进行一次flush 防止数据在内存中丢失

========================以下是题外话=============================
以上全部都是在语言层面上做出的优化 实际运行中 操作系统也会做优化 并不是实际调用了write方法 数据就会落到硬盘上 因为操作系统有IO缓存 所以保证数据真正落地的方法不仅仅是调用flush 还要调用java.io.FileDescriptor#sync()方法 这个方法是本地方法 我没看实现 不过应该就跟下面这个链接里说的是一回事

文件I/O编程之sync、fsync和fdatasync函数

fsync和write的区别,fsync函数作用

到此,以上就是小编对于fsync函数作用的问题就介绍到这了,希望介绍的2点解答对大家有用,有任何问题和不懂的,欢迎各位老师在评论区讨论,给我留言。

随机图文
    此处不必修改,程序自动调用!
  • 随机文章

  • 热门文章

  • 热评文章

sql语句自动生成(sql语句自动生成器)
2025-05-11  阅读(544)
  • B函数求解(函数b的求法)
    2025-05-13  阅读(458)
  • 周期函数,周函数的使用方法
    2025-05-15  阅读(582)
  • 用第三个表达式替换第一个字符串表达式中出现的所有第二个给定字符串表达式。

    语法

    REPLACE ( ''string_replace1'' , ''string_replace2'' , ''string_replace3'' )

    参数

    SqlServer中REPLACE函数的使用,sql替换字符串函数

    ''string_replace1''

    待搜索的字符串表达式。string_replace1 可以是字符数据或二进制数据。

    ''string_replace2''

    待查找的字符串表达式。string_replace2 可以是字符数据或二进制数据。

    SqlServer中REPLACE函数的使用,sql替换字符串函数

    在SQL Server中,REPLACE函数用于替换字符串中出现的指定子字符串。它接受三个参数:原字符串,要被替换的子字符串和替换后的子字符串。

    该函数会查找原字符串中的所有匹配项,并将其替换为指定的字符串。如果原字符串中不存在要替换的子字符串,则不会发生任何更改。使用REPLACE函数可以轻松地进行字符串替换操作,例如将某些特定字符替换为其他字符或将一部分文本替换为其他文本。这在数据清洗和字符串处理中非常有用。

    sourceinsight怎么替换字符串

    12。replace('string" class="zf_thumb" width="48" height="48" title="SqlServer中REPLACE函数的使用,sql替换字符串函数" />

  • SqlServer中REPLACE函数的使用,sql替换字符串函数
    2025-05-14  阅读(529)
  • 一个已知的函数有几个原函数,任意原函数之间的差值是
    2025-05-14  阅读(456)
  • sql server新建表(sql如何新建数据库)
    2025-05-15  阅读(461)
  • 数行函数(数行数的函数)
    2025-05-13  阅读(463)
  • mysql数据库,指定到某一时间,它就自动执行相应的操作?sql语句该怎么写,定时执行sql语句设置
    2025-05-15  阅读(563)
  • 最新留言