信息发布→ 登录 注册 退出

Linux C/C++多进程同时写一个文件(三)

发布时间:2025-07-21

点击量:

本文是《#%#$#%@%@%$#%$#%#%#$%@_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_7linux_process_fork1_8两个可执行文件。

/**
 * @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  # ai  # c++  # 字符串  # 指针  # append  # 出了  # 上一  # 这两个  # 只会  # 并将  # 如果没有  # 仍然是  # 其主要  # 命名为  # 值为  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!