嵌入式学习--IO进程线程

线程间通信与同步互斥1-flag

#include<stdio.h>
#include<pthread.h>
#include<unistd.h>
char str[]="123456";int flag=0;
void *callbackA(void *arg)
{
    while(1)
    {
        if(flag==1)
        {
            printf("str=%s\n",str);
            flag=0;
        }
    }
    pthread_exit(NULL);
}
void *callbackB(void *arg)
{
    char temp=0;
    while(1)
    {
        if(flag==0)
        {
            int i=0;
            while(i<3)
            {
                temp=str[i];
                str[i]=str[5-i];
                str[5-i]=temp;
                i++;
            }
            flag=1;
        }
    }
    pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{

    printf("程序开始运行\n");
    //创建子线程
    pthread_t tid1;
    pthread_t tid2;
    if(pthread_create(&tid1, NULL,callbackA,NULL)!=0)
    {
        perror("pthreadA");
        return -1;
    }
    if(pthread_create(&tid2, NULL,callbackB,NULL)!=0)
    {
        perror("pthreadB");
        return -1;
    }

    printf("线程创建成功\n");
    pthread_join(tid1,NULL);
    pthread_join(tid2,NULL);                         

    return 0;
}

result在这里插入图片描述

线程间互同步互斥 --互斥锁

#include<stdio.h>
#include<pthread.h>
#include<unistd.h>
#include<sys/stat.h>
#include<sys/types.h>
#include<fcntl.h>
char str[]="123456";int flag=0;
pthread_mutex_t mutex;
int size=0;
void *callbackA(void *arg)
{
        int *fd1=(int*)arg;
        int *fd2=(int*)arg+1;
        char c=0;
        pthread_mutex_lock(&mutex);

    lseek(*fd1,0,SEEK_SET);
    lseek(*fd2,0,SEEK_SET);
        int i=0;
        for(i=0;i<size/2;i++)
        {   int res=read(*fd1,&c,1);
            if(res<=0){break;}
            write(*fd2,&c,1);                                           
        }
        //sleep(1);
        printf("上半部分打印成功\n");
        printf("上半部分:fd1=%d,fd2=%d\n",*fd1,*fd2);
        pthread_mutex_unlock(&mutex);
    
    pthread_exit(NULL);
}
void *callbackB(void *arg)
{
        int *fd1=(int*)arg;
        int *fd2=(int*)arg+1;
        char c=0;
        
        pthread_mutex_lock(&mutex);

        int i=0;
        lseek(*fd1,size/2,SEEK_SET);
        lseek(*fd2,size/2,SEEK_SET);
        printf("size=%d",size);
    
    for(i=size/2;i<size+1;i++)
        {
            int res=read(*fd1,&c,1);
            if(res<=0)break;
            write(*fd2,&c,1);
        }
        printf("下半部分打印成功\n");
        printf("下半部分:fd1=%d,fd2=%d\n",*fd1,*fd2);

        pthread_mutex_unlock(&mutex);

    pthread_exit(NULL);
}
int main(int argc, const char *argv[])
{

    printf("程序开始运行\n");
    //创建锁
    if(pthread_mutex_init(&mutex,NULL)!=0)
    {
        perror("mutex");
        return -1;
    }

    int fd1=open("./origin.png",O_RDONLY);
    if(fd1<0){perror("open_fd1");return -1;}
    int fd2=open("./copy.png",O_WRONLY|O_CREAT|O_TRUNC,0777);
    if(fd2<0){perror("open_fd2");return -1;}
    size = lseek(fd1,0,SEEK_END);   
    int fd[2]={fd1,fd2};
        printf("主程序:fd1=%d,fd2=%d",fd1,fd2);
    //创建子线程
    pthread_t tid1;//拷贝前半部分
    pthread_t tid2;//拷贝后半部分
    if(pthread_create(&tid1, NULL,callbackA,(void*)fd)!=0)
    {   
        perror("pthreadA");
        return -1;
    }
    if(pthread_create(&tid2, NULL,callbackB,(void*)fd)!=0)
    {
        perror("pthreadB");
        return -1;
    }

    printf("线程创建成功\n");
    pthread_join(tid1,NULL);
    pthread_join(tid2,NULL);
close(fd1);
close(fd2);
    pthread_mutex_destroy(&mutex);


    return 0;
}

result

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值