本文是《#%#$#%@%@%$#%$#%#%#$%@_e206a54e97690c++e50cc872dd70ee896 c/c++多进程同时写一个文件》系列的第三篇,承接上一篇文章中关于两个亲缘关系进程(父子进程)同时写入文件的讨论,并得出了“数据只会错乱但不会覆盖”的结论。本文将进一步探讨两个非亲缘关系进程同时写入一个文件的现象。
首先,我们通过stat LINUX_MUTIL_PROCESS_WRITE_2命令查看目标文件的inode信息,发现其值为67728087。

接下来,我们将执行两个测试程序来模拟这种情景。
示例程序linux_process_fork1_7.c非常简单,其主要功能是将静态区数据通过p_buf指针写入到文件LINUX_MUTIL_PROCESS_WRITE中。为了测试多进程同时写入文件的情况,我们复制了linux_process_fork1_7.c程序并命名为linux_process_fork1_8.c,并将p_buf指向的字符串改为abcdefghi。然后,我们分别编译这两个程序,生成linux_process_fork1_7和linux_process_fork1_8两个可执行文件。
立即学习“C++免费学习笔记(深入)”;
/** * @FileName linux_process_fork1_7.c * @Describe Linux C/C++多进程同时写一个文件(三) * @Author vfhky 2017-10-29 22:23 https://typecodes.com/cseries/linuxmutilprocesswrite3.html * @Compile gcc linux_process_fork1_7.c -o linux_process_fork1_7 */#include #include #include #include #include "printnolog.h"define FILE_NAME "LINUX_MUTIL_PROCESS_WRITE_2"
static const char *p_buf = "123456789";
int main(const int argc, const char const argv) {int i_fd = open(FILE_NAME, O_RDWR | O_CREAT);if (-1 == i_fd) {PRINTNOLOG("Open file=%s failed, errno=%d errmsg=%s.n", FILE_NAME, errno, strerror(errno));return -1;}static int i_write_len = 0;for (int i = 0; i < 10000; ++i) {if (-1 == lseek(i_fd, 0L, SEEK_END)) {// PRINTNOLOG("lseek error.n");// return 0;}usleep(1000);i_write_len += write(i_fd, p_buf, strlen(p_buf));}close(i_fd);PRINTNOLOG("i_write_len=%ld.n", i_write_len);return 0;}
具体的测试过程与第一篇文章类似:


测试结果显示,两个非亲缘进程分别写入了90000字节,但文件的总大小仍然是90000字节。

由此可以得出结论:当两个非亲缘关系的进程同时写入一个文件时,如果没有设置append同步文件偏移量,两个进程写入的数据会出现覆盖的情况。
以上就是Linux C/C++多进程同时写一个文件(三)的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/10164.html
微信扫一扫
支付宝扫一扫