首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C语言 >

求好手解释,关于2个互斥量,是uinx程序清单11-6,程序不太懂

2013-01-23 
求高手解释,关于2个互斥量,是uinx程序清单11-6,程序不太懂#include stdlib.h#include pthread.h#defin

求高手解释,关于2个互斥量,是uinx程序清单11-6,程序不太懂
#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;
pthread_mutex_t f_lock;
struct foo *f_next;
int f_id;
};
struct foo*
foo_alloc(void)
{
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;//这里2行代码不知道什么意思,还有??????????
pthread_mutex_lock(&fp->f_lock);
pthread_mutex_unlock(&hashlock);

pthread_mutex_unlock(&fp->f_lock);

}
return fp;
}
void foo_hold(struct foo *fp)
{
pthread_mutex_lock(&fp->f_lock);
fp->f_count++;
pthread_mutex_unlock(&fp->f_lock);
}
struct foo *
foo_find(int id)
{
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){
   foo_hold(fp);
   break;
}
}
pthread_mutex_unlock(&hashlock);
return fp;
}
void foo_rele(struct foo *fp)//这个函数帮忙解释一下 啊,谢谢量
{
struct foo *tfp;
int idx;
pthread_mutex_lock(&fp->f_lock);
if(fp->f_count==1){
   pthread_mutex_unlock(&fp->f_lock);
   pthread_mutex_lock(&hashlock);
   pthread_mutex_lock(&fp->f_lock);
if(fp->f_count!=1){
fp->f_count--;
pthread_mutex_unlock(&fp->f_lock);
pthread_mutex_unlock(&hashlock);
     return;
}
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(&fp->f_lock);
   pthread_mutex_unlock(&hashlock);
   pthread_mutex_unlock(&fp->f_lock);
   pthread_mutex_destroy(&fp->f_lock);
   free(fp);
}
else{
fp->f_count--;
pthread_mutex_unlock(&fp->f_lock);
}
}
int main(void)
{
return 0;
}

[解决办法]
fp->f_next = fh[idx];//
fh[idx]=fp->f_next;//这里2行代码不知道什么意思,还有??????????

這裡是不是錯了,應該為 fh[idx]=fp;

一個簡單的鏈表,fh[idx]是鏈表的頭.
每次新的節點都加到頭部,作爲新的表頭.

for(fp=fh[idx];fp!=NULL;fp=fp->f_next){//这里也不懂,这里用到量链表????
遍歷fh[idx]指向的整個鏈表.

void foo_rele(struct foo *fp)//这个函数帮忙解释一下 啊,谢谢量
刪除struct foo *fp節點, 釋放struct foo *fp的内存

热点排行