- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我有以下与处理文件和映射文件 (mmap
) 相关的问题:
mmap
将该文件映射到内存然后写入呢?mmap
实现的保护 - PROT_NONE
、PROT_READ
、PROT_WRITE
,那么使用文件也可以实现相同级别的保护。 O_RDONLY
, O_RDWR
等。那为什么要mmap
?mmap
一个文件到内存,如果我们写入 mmap 返回的那个内存位置,它是否也同时写入那个文件?据我所知,如果我们在两个线程(不是进程)之间共享一个文件,那么建议将它mmap
到内存中然后使用它,而不是直接使用该文件。
但我们知道使用文件意味着,它肯定在主内存中,那么为什么还要对线程进行映射?
最佳答案
内存映射文件实际上部分或全部映射到内存 (RAM) 中,而您写入的文件将写入内存,然后刷新到磁盘。内存映射文件从磁盘中取出并显式放入内存中以供读取和/或写入。它会一直留在那里,直到您取消映射。
对磁盘的访问速度较慢,因此当您写入文件后,它将被刷新到磁盘并且不再驻留在 RAM 中,这意味着,下次您需要该文件时,您可能会得到它从磁盘(慢),而在内存映射文件中,你知道文件在 RAM 中,你可以比在磁盘上更快地访问它。
此外,内存映射文件通常用作 IPC 机制,因此两个或多个进程可以轻松共享同一个文件并对其进行读/写。 (使用必要的sycnh机制)
当你需要经常读取一个文件,而且这个文件非常大时,将它映射到内存中是有好处的,这样你就可以更快地访问它,而不必每次都打开它并从磁盘中获取它。
编辑:
这取决于您的需求,当您有一个文件需要被不同线程频繁访问时,我不确定内存映射该文件是否一定是个好主意,从这个角度来看,如果您希望它写入它,您需要同步访问这个 mmap'ed 文件,在不同线程的相同位置。如果这种情况经常发生,则可能是资源争用的场所。
只是从文件中读取,那么这可能是一个很好的解决方案,因为如果您仅从多个线程中读取文件,那么您实际上并不需要同步访问。在您开始写作的那一刻,您确实必须使用同步机制。
我建议,如果您必须写入文件,就像处理任何其他文件一样,您可以让每个线程以线程本地方式执行自己的文件访问。通过这种方式,它减少了对线程同步的需要以及难以发现和调试的错误的可能性。
关于c - 写入文件和映射内存有什么区别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7280867/
我有这个代码 var myChart = new FusionCharts("../themes/clean/charts/hbullet.swf", "myChartId", "400", "75
既然写入是立即进行的(复制到内核缓冲区并返回),那么使用 io_submit 进行写入有什么好处? 事实上,它 (aio/io_submit) 看起来更糟,因为您必须在堆上分配写入缓冲区并且不能使用基
我正在使用 mootool 的 Request.JSON 从 Twitter 检索推文。收到它后,我将写入目标 div 的 .innerHTML 属性。当我在本地将其作为文件进行测试时,即 file:
最终,我想将 Vertica DB 中的数据抓取到 Spark 中,训练机器学习模型,进行预测,并将这些预测存储到另一个 Vertica DB 中。 当前的问题是确定流程最后部分的瓶颈:将 Spark
我使用 WEKA 库编写了一个 Java 程序, 训练分类算法 使用经过训练的算法对未标记的数据集运行预测 将结果写入 .csv 文件 问题在于它当前写出离散分类结果(即算法猜测一行属于哪个类别)。我
背景 - 我正在考虑使用 clickonce 通过 clickonce(通过网站)部署 WinForms 应用程序。相对简单的应用程序的要素是: - 它是一个可执行文件和一个数据库文件(sqlite)
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
我正在读取 JSON 文件,取出值并进行一些更改。 基本上我向数组添加了一些值。之后我想将其写回到文件中。当我将 JSONArray 写回文件时,会被写入字符串而不是 JSONArray 对象。怎样才
我为两个应用程序使用嵌入式数据库,其中一个是服务器,另一个是客户端。客户端应用程序。可以向服务器端发送获取数据请求以检索数据并显示在表格(或其他)中。问题是这样的:如何将获取的数据保存(写入)到页面文
是否有更好的解决方案来快速初始化 C 数组(在堆上创建)?就像我们使用大括号一样 double** matrix_multiply(const double **l_matrix, const dou
从问题得出问题:找到所有 result = new ArrayList(); for (int i = 2; i >(i%8) & 0x1) == 0) { result.add(i
由于某种原因,它没有写入 CSV。谁能明白为什么它不写吗? def main(): list_of_emails = read_email_csv() #read input file, cr
关闭。 这个问题是 not reproducible or was caused by typos 。它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能在这里出现,
我目前正在开发一个保存和加载程序,但我无法获得正确的结果。 编写程序: #include #include #define FILENAME "Save" #define COUNT 6 type
import java.io.*; public class Main2 { public static void main(String[] args) throws Exception {
我需要使用预定义位置字符串“Office”从所有日历中检索所有 iOS 事件,然后将结果写入 NSLog 和 UITextView。 到目前为止,这是我的代码: #import "ViewCo
我正在尝试将 BOOL 值写入 PFInstallation 中的列,但会不停地崩溃: - (IBAction)pushSwitch:(id)sender { NSUserDefaults *push
我以前在学校学过一些简单的数据库编程,但现在我正在尝试学习最佳实践,因为我正在编写更复杂的应用程序。写入 MySQL 数据库并不难,但我想知道让分布式应用程序写入 Amazon EC2 上的远程数据库
是否可以写回到ResourceBundle?目前我正在使用 ResourceBundle 来存储信息,在运行时使用以下内容读取信息 while(ResourceBundle.getBundle("bu
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我是一名优秀的程序员,十分优秀!