线程中用信号量进行同步( sem_init(),sem_wait(),sem_post(),sem_destroy() )

函数头文件为: #include <semaphore.h>

int sem_init(sem_t *sem,int pshared,unsigned int value)


第一个参数是sem_t结构指针,该结构用于保存信号量的信息。

第二个参数控制信号量的类型,如果参数值为0,表示该信号量是局部的,否则其他程序就能共享这个信号量。

第三个参数是信号量的初始值。

int sem_wait(sem_t *sem)

int sem_post(sem_t *sem)

int sem_destroy(sem_t *sem)

信号量的操作方法:


#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
#include <semaphore.h>

void *thread_function(void *arg);  //定义线程函数原型
sem_t bin_sem;                     //定义信号量原型
#define WORK_SIZE 1024
char work_area[WORK_SIZE];
int main ()
{
    int res;
    pthread_t a_thread;
    void *thread_result;
    res=sem_init(&bin_sem,0,0);
    if(res!=0)
    {
        perror("初始化信号量失败");
        exit(EXIT_FAILURE);
    }
    res=pthread_create(&a_thread,NULL,thread_function,NULL);
    if(res!=0)
    {
        perror("线程创建失败");
                         exit(EXIT_FAILURE);
    }
    printf("请输入传送的信息,输入end退出\n");
    while(strncmp("end",work_area,3)!=0)
    {
        fgets(work_area,WORK_SIZE,stdin);
        sem_post(&bin_sem);   //将信号量加1

    }
    printf("\n等待线程结束......\n");
    res=pthread_join(a_thread,&thread_result);
    if(res!=0)
    {
        perror("等待线程创建失败");
        exit(EXIT_FAILURE);
    }
    printf("线程结束\n");
    sem_destroy(&bin_sem);
    exit(EXIT_SUCCESS);
}
void *thread_function(void *arg)
{
    sem_wait(&bin_sem);  //等待信号量变化 将信号量减一
    while(strncmp("end",work_area,3)!=0)
    {
        printf("收到数据是%s\n",work_area);
        sem_wait(&bin_sem); //等待信号量变化 将信号量减一
    }
    pthread_exit(NULL);
}
        


`sem_init` 是 POSIX 标准中定义的一个函数,用于初始化一个未命名的信号量信号量是一种同步机制,用于控制多个进程或线程对共享资源的访问。初始化信号量时,可以设置一个初始值,该值表示资源的数量或者允许的并发访问数。 下面是一个使用 `sem_init` 初始化信号量的简单示例代码: ```c #include <stdio.h> #include <semaphore.h> #include <pthread.h> #include <unistd.h> #define MAX_COUNT 10 sem_t sem; // 未命名信号量 void* thread_function(void* arg) { int id = *((int*)arg); while (1) { sem_wait(&sem); // 等待信号量(获取资源) printf("线程 %d: 已获取资源,正在工作。\n", id); sleep(1); // 模拟工作 printf("线程 %d: 完成工作,释放资源。\n", id); sem_post(&sem); // 释放信号量(释放资源) sleep(1); // 模拟线程的其他任务 } return NULL; } int main() { pthread_t threads[MAX_COUNT]; int ids[MAX_COUNT]; // 初始化信号量,初始计数为1 if (sem_init(&sem, 0, 1) != 0) { perror("sem_init error"); return 1; } // 创建线程 for (int i = 0; i < MAX_COUNT; i++) { ids[i] = i; if (pthread_create(&threads[i], NULL, thread_function, (void*)&ids[i]) != 0) { perror("pthread_create error"); return 1; } } // 等待线程结束 for (int i = 0; i < MAX_COUNT; i++) { pthread_join(threads[i], NULL); } // 销毁信号量 sem_destroy(&sem); return 0; } ``` 这段代码创建了一个包含10个线程线程池,每个线程都会尝试获取信号量以执行其工作。信号量的初始值设置为1,这意味着一次只有一个线程能够通过 `sem_wait` 获取资源并进行工作。当线程完成工作后,它通过 `sem_post` 释放资源,允许其他线程获取资源。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值