Linux-----进程处理(文件IO资源使用)

下面代码是通过父进程和子进程对同一个文件IO资源进行操作,父进程和子进程都对这个进程进行写入操作,我们都知道这两个进程实际上是并发的,所以需要一个同步机制来去操作同一个资源(后面再深入去说明同步的api,这里使用延时就可以解决了),解释如下:

cpp 复制代码
#include <sys/stat.h>
#include <stdio.h>
#include <stdlib.h> 
#include <unistd.h>
#include <fcntl.h>
#include <string.h>

int main(int argc, char const* argv[])
{
    int fd = open("./io.txt", O_CREAT | O_WRONLY | O_APPEND, 0644);

    if (fd == -1) {
        perror("open");
        exit(EXIT_FAILURE);
    }

    char buffer[1024]; // 文件读取缓冲区


    pid_t pid = fork();

    if (pid < 0) {
        perror("fork");
        exit(EXIT_FAILURE);
    }

    // 子进程
    else if (pid==0){
        strcpy(buffer, "这是子进程写入的数据\n");
    }
    // 父进程
    else {
        sleep(1);
        strcpy(buffer, "这是父进程写入的数据\n");
    }
    // 父子进都执行的代码
    ssize_t byte_wirte = write(fd, buffer, strlen(buffer));

    if (byte_wirte == -1) {
        perror("write");
        close(fd);
        exit(EXIT_FAILURE);
    }

    // 使用完毕资源后关闭
    
    printf("写入数据成功\n");
    close(fd);

    if (pid == 0) {
        printf("子进程写入完毕\n");
        
    }
    else {
        printf("父进程写入完毕\n");
        // close(fd);
    }

    return 0;
}
相关推荐
十年磨一剑~5 分钟前
Linux程序接收到sigpipe信号崩溃处理
linux
geshifei12 分钟前
Sched ext回调3——select_cpu(linux 6.15.7)
linux·ebpf
yunfuuwqi17 分钟前
OpenClaw✅真·喂饭级教程:2026年OpenClaw(原Moltbot)一键部署+接入飞书最佳实践
运维·服务器·网络·人工智能·飞书·京东云
迎仔32 分钟前
C-算力中心网络隔离实施方法:怎么搞?
运维·网络
代码游侠36 分钟前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法
你真是饿了39 分钟前
6.库制作与原理
linux·服务器
2301_763472461 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
abluckyboy2 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
园小异2 小时前
2026年技术面试完全指南:从算法到系统设计的实战突破
算法·面试·职场和发展
m0_706653232 小时前
分布式系统安全通信
开发语言·c++·算法