openwrt linux 多线程并发 采用信号量的方式 特定线程挂起和释放 帮忙写一个C demo
时间: 2024-10-09 11:01:23 浏览: 45
OpenWRT Linux是一个轻量级的嵌入式Linux发行版,常用于路由器和网络设备。在多线程并发处理中,信号量是一种同步机制,可以控制对共享资源的访问。下面是一个简单的C示例,展示了如何使用信号量(Semaphore)来管理特定线程的挂起和释放:
```c
#include <semaphore.h>
#include <pthread.h>
// 初始化信号量
sem_t semaphore;
sem_init(&semaphore, 0, 1); // 设置初始计数为1
void* thread_func(void* arg) {
int result;
while (1) {
// 尝试获取信号量
result = sem_wait(&semaphore);
if (result == -1 && errno == EINTR) continue; // 如果中断,忽略并继续
printf("Thread running...\n"); // 线程正在执行
// ...你的业务逻辑...
// 执行完毕后,释放信号量
sem_post(&semaphore);
}
}
int main() {
pthread_t thread_id;
pthread_attr_t attr;
// 设置线程属性
pthread_attr_init(&attr);
pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
// 创建新线程
if (pthread_create(&thread_id, &attr, thread_func, NULL)) {
perror("Error creating thread");
return -1;
}
printf("Main thread waiting for semaphore to be released...\n");
// 模拟主线程等待,直到子线程完成任务
for (int i = 0; i < 10; ++i) {
sleep(1); // 每秒检查一次
}
// 主线程不再需要信号量,直接结束
printf("Main thread exiting.\n");
return 0;
}
```
在这个示例中,`sem_wait`函数会阻塞当前线程,直到信号量计数大于0。当子线程执行完一段代码后通过`sem_post`增加信号量,使得其他等待的线程可以继续执行。`EINTR`错误表示收到中断,通常发生在系统调用被信号打断时。
阅读全文