本文主要是介绍posix信号量和systemv信号量,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1. posix 无名信号量 : 进程持续 ,其实就是计数器不止1 的互斥锁
#include <stdio.h>
#include <pthread.h>
#include <semaphore.h>
/*使用信号量保护临界资源的访问*/
/*临界资源*/
char* data[5];
int size = 0;
/*信号量*/
sem_t lock;
void* task1(void* p){sem_wait(&lock);//加锁 // 如果信号量的值大于 0,那么 sem_wait 会立即成功返回,并将信号量的值减 1。但是,如果信号量的值为 0(表示没有可用的资源),那么 sem_wait 会阻塞调用线程,直到信号量的值变为非零(即有其他线程或进程调用了 sem_post 来增加信号量的值)。data[size] = "鲁科";sleep(1);size++;sem_post(&lock);//解锁
}
void* task2(void* p){sem_wait(&lock);//加锁data[size] = "张冠";sleep(1);size++;sem_post(&lock);//解锁
}int main()
{sem_init(&lock, 0, 1);//初始化信号量data[size] = "李振";size++;pthread_t id1, id2;pthread_create(&id1, 0, task1, 0);pthread_create(&id2, 0, task2, 0);pthread_join(id1, 0);pthread_join(id2, 0);int i;for(i=0; i<size; i++){printf("%s ", data[i]);}printf("\n");sem_destroy(&lock);
}
2. posix有名信号量: 内核持续 使用sem_open
函数创建或打开
// semaphore_lock.h
#ifndef SEMAPHORE_LOCK_H
#define SEMAPHORE_LOCK_H #include <semaphore.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <unistd.h> #define SEM_NAME "/my_semaphore" // 初始化信号量
void init_semaphore();
// 锁定信号量
void lock_semaphore();
// 解锁信号量
void unlock_semaphore();
// 清理信号量
void cleanup_semaphore(); #endif // SEMAPHORE_LOCK_H
// semaphore_lo
这篇关于posix信号量和systemv信号量的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!