有四个线程1、2、3、4。线程1的功能就是输出1,线程2的功能就是输出2,以此类推.........现在有四个文件ABCD

该博客介绍了一个使用POSIX线程和信号量实现的多线程并发写入文件的示例。四个线程分别负责向四个文件ABCD中按顺序写入数字1到4,形成循环输出。通过信号量机制控制线程间的同步,确保正确写入顺序。示例代码详细展示了如何初始化线程和信号量,以及处理信号中断。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/****************************************************************
 有四个线程1、2、3、4。
 线程1的功能就是输出1,线程2的功能就是输出2,以此类推
 现在有四个文件ABCD。初始都为空。现要让四个文件呈如下格式:
A:1 2 3 4 1 2....
B:2 3 4 1 2 3....
C:3 4 1 2 3 4....
D:4 1 2 3 4 1....
********************************************************************/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h>
#include <fcntl.h>
#include <pthread.h>
#include <semaphore.h>
#include <signal.h>

pthread_t ids[4];

int fds[4];

sem_t sems[4];//定义信号量

void my_exit(int sig)
{
    for (int i = 0; i < 4; i++)//关线程
    {
       pthread_cancel(ids[i]);
       sem_destroy(sems+i);
    }
    
}

void * write_A(void *arg)
{
    int flag=0;
    char temp='A';
    while (1)
    {
        sem_wait(&sems[0]);

        for(int i=0;i<4;i++)
        {
            if (flag !=0 || i<=0)
            {
               write(fds[i],&temp,1);
            }         
        }
        flag=1;
        sem_post(&sems[1]);
    }    
}
void * write_B(void *arg)
{
    int flag=0;
    char temp='B';
    while (1)
    {
        sem_wait(&sems[1]);

        for(int i=0;i<4;i++)
        {
            if (flag !=0 || i<=1)
            {
               write(fds[i],&temp,1);
            }
            
        }
        flag=1;
        sem_post(&sems[2]);
    }
}
void * write_C(void *arg)
{
    int flag=0;
    char temp='C';
    while (1)
    {
        sem_wait(&sems[2]);

        for(int i=0;i<4;i++)
        {
            if (flag !=0 || i<=2)
            {
               write(fds[i],&temp,1);
            }
            
        }
        flag=1;
        sem_post(&sems[3]);
    }
}
void * write_D(void *arg)
{
    int flag=0;
    char temp='D';
    while (1)
    {
        sem_wait(&sems[3]);

        for(int i=0;i<4;i++)
        {
            if (flag !=0 || i<=3)
            {
               write(fds[i],&temp,1);
            }
            
        }
        flag=1;
        sem_post(&sems[0]);
    }
}

void open_file()
{
    char temp[1]="A";

    for (int i = 0; i < 4; i++)
    {
        temp[0]='A';
        temp[0]=temp[0]+i;
        if ((fds[i]=open(temp,O_RDWR | O_CREAT | O_TRUNC,0655))<0)
        {
            printf("打开文件错误!");
            exit(-1);
        }
        
    }
    
}

void init_sems()//初始化信号量
{
    for (int i = 0; i < 4; i++)
    {
        if(i==0)
        {
            sem_init(sems+i,0,1);
        }
        else
        {
            sem_init(sems+i,0,0);
        }
    }
    
}

int main(int argc,char **argv)
{
    int ret;
    int i;
    signal(SIGINT,my_exit);
    open_file();
    init_sems();
    void *(*p_func[4])(void *)={write_A,write_B,write_C,write_D};

    for ( i = 0; i < 4; i++)
    {
        ret=pthread_create(ids+i,NULL,p_func[i],NULL);

        if (ret<0)
        {
            perror("pthread create error!\n");
            exit(1);
        }
        pthread_detach(ids[i]);//自由回收
        
        
    }
    pause();//挂起
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值