我在Python文档的FileObjects中找到了这个:
flush()不一定会将文件的数据写入磁盘。使用flush()和os.fsync()来确保此行为。
所以我的问题是:Python到底在flush
做什么?我以为这会强制将数据写入磁盘,但现在我知道并没有。为什么?
通常涉及两个级别的缓冲:
内部缓冲区是由您要针对其进行编程的运行时/库/语言创建的缓冲区,旨在通过避免每次写入都导致系统调用来加快处理速度。取而代之的是,当您写入文件对象时,您将写入其缓冲区,并且只要缓冲区被填满,就会使用系统调用将数据写入实际文件。
但是,由于操作系统缓冲区的原因,这可能并不意味着数据已写入 disk 。这可能仅意味着将数据从运行时维护的缓冲区复制到操作系统维护的缓冲区。
如果您写了一些东西,并且它最终在缓冲区中(仅),并且切断了计算机的电源,则当计算机关闭时,该数据将不在磁盘上。
因此,为了帮助您在各自的对象上使用flush
和fsync
方法。
第一个flush
会简单地将程序缓冲区中残留的所有数据写到实际文件中。通常,这意味着数据将从程序缓冲区复制到操作系统缓冲区。
具体来说,这意味着如果另一个进程打开了要读取的相同文件,它将能够访问刚刚刷新到该文件的数据。但是,这不一定意味着它已“永久”存储在磁盘上。
为此,您需要调用该os.fsync
方法以确保所有操作系统缓冲区均与其所使用的存储设备同步,换句话说,该方法会将数据从操作系统缓冲区复制到磁盘。
通常,您无需为这两种方法烦恼,但是,如果您对磁盘上实际存储的内容抱有偏执是好事,则应按照指示进行两次调用。
2018年补遗。
请注意,具有缓存机制的磁盘现在比2013年更加普遍,因此现在涉及的缓存和缓冲区级别更高。我 认为 这些缓冲区也将由sync /
flush调用处理,但是我真的不知道。
问题内容: 我对Python来说还很陌生,并且完全不理解所读内容是连接字符串的首选方法。 我试过了: 并得到类似: 为什么会这样工作?难道不595应该自动追加吗? 问题答案: 仔细查看你的输出: 我突出显示了原始字符串的“ 5”,“ 9”,“ 5”。Python的join()方法是一个字符串的方法,而且占据了名单的事情,加入以字符串。一个简单的示例可能有助于解释: 在给定列表的每个元素之间插入“,
问题内容: 在Tour of Go网站的go 1.5发行之前的版本中,有一段代码看起来像这样。 输出看起来像这样: 令我困扰的是,将其删除后,该程序不再显示“世界”。 为什么呢?如何影响执行力? 问题答案: 注意: 从Go 1.5开始,将GOMAXPROCS设置为硬件内核数:golang.org/doc/go1.5#runtime,低于1.5之前的原始答案。 当您在未指定GOMAXPROCS环境变
根据几个因素(包括OS/浏览器组合),WebDriver可能等待或不等待页面加载。在某些情况下,WebDriver可能会在页面完成加载或甚至开始加载之前返回控制 有人能解释一下在什么情况下WebDriver会在页面完成甚至开始加载之前返回控制吗?
我有一个Spring Boot后端,我刚刚解决了从Angular frontend上传文件时的“ERR_CONNECTION_RESET”问题,方法是配置Tomcat属性。我想弄清楚它到底是做什么的。Tomcat文档对我来说并不明显: 对于中止的上载,Tomcat将吞下的最大请求主体字节数(不包括传输编码开销)。中止上载是指Tomcat知道请求正文将被忽略,但客户端仍然发送它。如果Tomcat没有
问题内容: 这是我的代码: 这是我从解释器运行输出时的结果: 如果您注意到输出,则创建巨大的列表会消耗621.5 MB,而删除它只会释放152.6 MB。当我检查文档时,我发现以下语句: 因此,我猜想它并没有删除对象本身,而只是取消了绑定。 但是,它在解除绑定方面做了什么工作,从而释放了很大的空间(152.6 MB) 。有人可以痛苦地解释我在这里发生什么吗? 问题答案: Python是一种垃圾收集
我很难理解的概念,因为根据视图,它做不同的事情。根据官方的留档,这是一个 用于根据系统窗口(如状态栏)调整视图布局的布尔内部属性。如果为true,则调整此视图的填充以为系统窗口留出空间。 现在,检查class我可以看到,当设置为时,窗口会插入(状态栏、导航栏…)应用于视图填充,该填充根据上面引用的文档工作。这是守则的相关部分: 有了新的材料设计,有了新的类别,这些类别广泛地使用了这面旗帜,这就是混