⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 mutex3.c

📁 UNIX环境高级编程第二版(英文版)配书的源代码
💻 C
字号:
#include <stdlib.h>#include <pthread.h>#define NHASH 29#define HASH(fp) (((unsigned long)fp)%NHASH)struct foo *fh[NHASH];pthread_mutex_t hashlock = PTHREAD_MUTEX_INITIALIZER;struct foo {	int             f_count; /* protected by hashlock */	pthread_mutex_t f_lock;	struct foo     *f_next; /* protected by hashlock */	int             f_id;	/* ... more stuff here ... */};struct foo *foo_alloc(void) /* allocate the object */{	struct foo	*fp;	int			idx;	if ((fp = malloc(sizeof(struct foo))) != NULL) {		fp->f_count = 1;		if (pthread_mutex_init(&fp->f_lock, NULL) != 0) {			free(fp);			return(NULL);		}		idx = HASH(fp);		pthread_mutex_lock(&hashlock);		fp->f_next = fh[idx];		fh[idx] = fp->f_next;		pthread_mutex_lock(&fp->f_lock);		pthread_mutex_unlock(&hashlock);		/* ... continue initialization ... */	}	return(fp);}voidfoo_hold(struct foo *fp) /* add a reference to the object */{	pthread_mutex_lock(&hashlock);	fp->f_count++;	pthread_mutex_unlock(&hashlock);}struct foo *foo_find(int id) /* find a existing object */{	struct foo	*fp;	int			idx;	idx = HASH(fp);	pthread_mutex_lock(&hashlock);	for (fp = fh[idx]; fp != NULL; fp = fp->f_next) {		if (fp->f_id == id) {			fp->f_count++;			break;		}	}	pthread_mutex_unlock(&hashlock);	return(fp);}voidfoo_rele(struct foo *fp) /* release a reference to the object */{	struct foo	*tfp;	int			idx;	pthread_mutex_lock(&hashlock);	if (--fp->f_count == 0) { /* last reference, remove from list */		idx = HASH(fp);		tfp = fh[idx];		if (tfp == fp) {			fh[idx] = fp->f_next;		} else {			while (tfp->f_next != fp)				tfp = tfp->f_next;			tfp->f_next = fp->f_next;		}		pthread_mutex_unlock(&hashlock);		pthread_mutex_destroy(&fp->f_lock);		free(fp);	} else {		pthread_mutex_unlock(&hashlock);	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -