#include <stdlib.h>
#include <pthread.h>
struct foo{
int count;
struct foo *
foo_alloc(void)
{
struct foo *fp;
if((fp=malloc(sizeof(struct foo)))!=NULL);
{
fp->count = 1;
if(pthread_mutex_init(&fp->mutex,NULL)!=0)
{
free(fp);
return(NULL);
return (fp);
}
void
mutex_hold(struct foo *fp)
{
pthread_mutex_lock(&fp->mutex);
fp->count++;
pthread_mutex_unlock(&fp->mutex);
}
void
mutex_rele(struct foo *fp)
{
pthread_mutex_lock(&fp->mutex);
if(--fp->count==0){
pthread_mutex_destroy(&fp->mutex);
free(fp);
}else {
pthread_mutex_unlock(&fp->mutex);
}
}
#include <pthread.h>
struct foo{
int count;
pthread_mutex_t mutex;
/*other struction*/
};struct foo *
foo_alloc(void)
{
struct foo *fp;
if((fp=malloc(sizeof(struct foo)))!=NULL);
{
fp->count = 1;
if(pthread_mutex_init(&fp->mutex,NULL)!=0)
{
free(fp);
return(NULL);
}
/*initilize other parts*/
}return (fp);
}
void
mutex_hold(struct foo *fp)
{
pthread_mutex_lock(&fp->mutex);
fp->count++;
pthread_mutex_unlock(&fp->mutex);
}
void
mutex_rele(struct foo *fp)
{
pthread_mutex_lock(&fp->mutex);
if(--fp->count==0){
pthread_mutex_destroy(&fp->mutex);
free(fp);
}else {
pthread_mutex_unlock(&fp->mutex);
}
}
线程同步与资源管理
本文介绍了一个使用pthread线程库实现的资源管理结构。该结构包含一个计数器和互斥锁,用于多线程环境下的资源分配与释放。通过mutex_hold和mutex_rele函数确保了线程安全。
1万+

被折叠的 条评论
为什么被折叠?



