本文是《#%#$#%@%@%$#%$#%#%#$%@_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同步文件偏移量,两个进程写入的数据会出现覆盖的情况。










