当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 7 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 我也在学多线程,pthread_cond_timedwait()有点不懂
帖子发表于 : 2008-11-29 20:02 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
代码:
/**
 * 好像没有想像的那样简单啊
 */
#include <stdio.h>
#include <pthread.h>
#include <time.h>

void my_thread_func_1();
struct timespec waitcount;
pthread_cond_t cond_t;
pthread_mutex_t mutex_t;

int main(void)
{
   int i = 5;
   pthread_t pid;
   void *retval;

   waitcount.tv_sec = 10;
   waitcount.tv_nsec = 0;
   
   // 初始化线程相关的一些变量
   pthread_cond_init(&cond_t, NULL);
   pthread_mutex_init(&mutex_t, NULL);

   while (i > 0)
   {
      pthread_create(&pid, NULL, (void *)&my_thread_func_1, NULL);
      i--;
   }
   // pthread_join(pid, &retval);
}

void my_thread_func_1()
{
   pthread_mutex_lock(&mutex_t);
   // 把锁释放掉,然后1秒种后重新去竞争锁
   pthread_cond_timedwait(&cond_t, &mutex_t, &waitcount);
   printf("a\n");
   pthread_mutex_unlock(&mutex_t);
}

我想要得到的是10秒钟后再打印5个a
编译后,却是立即打印5个a

我对pthread_cond_timedwait()理解不对?


_________________
Say hello to everyday!


页首
 用户资料  
 
2 楼 
 文章标题 : Re: 我也在学多线程,pthread_cond_timedwait()有点不懂
帖子发表于 : 2008-11-29 21:40 
头像

注册: 2005-12-28 1:16
帖子: 3916
地址: 火星
系统: Ubuntu 12.10 X64
送出感谢: 1
接收感谢: 0 次
代码:
#include <pthread.h>

struct msg {
    struct msg *m_next;
    /* ... more stuff here ... */
};
struct msg *workq;
pthread_cond_t qready = PTHREAD_COND_INITIALIZER;
pthread_mutex_t qlock = PTHREAD_MUTEX_INITIALIZER;

void
process_msg(void)
{
    struct msg *mp;

    for (;;) {
        pthread_mutex_lock(&qlock);
        while (workq == NULL)
            pthread_cond_wait(&qready, &qlock);
        mp = workq;
        workq = mp->m_next;
        pthread_mutex_unlock(&qlock);
        /* now process the message mp */
    }
}

void
enqueue_msg(struct msg *mp)
{
    pthread_mutex_lock(&qlock);
    mp->m_next = workq;
    workq = mp;
    pthread_mutex_unlock(&qlock);
    pthread_cond_signal(&qready);
}



apue上的例子,可以参考下


_________________
目前负债150多万


页首
 用户资料  
 
3 楼 
 文章标题 : Re: 我也在学多线程,pthread_cond_timedwait()有点不懂
帖子发表于 : 2008-11-30 19:29 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
今天去翻了下这本书,....................很是枯燥


_________________
Say hello to everyday!


页首
 用户资料  
 
4 楼 
 文章标题 : Re: 我也在学多线程,pthread_cond_timedwait()有点不懂
帖子发表于 : 2008-12-01 22:56 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
代码:
#include <stdio.h>
#include <pthread.h>
#include <sys/time.h>
#include <time.h>

void my_thread_func_1();
struct timespec waitcount;
pthread_cond_t cond_t;
pthread_mutex_t mutex_t;

int main(void)
{
   int i = 5;
   pthread_t pid;
   void *retval;
   
   
   pthread_cond_init(&cond_t, NULL);
   pthread_mutex_init(&mutex_t, NULL);

   while (i > 0)
   {
      pthread_create(&pid, NULL, (void *)&my_thread_func_1, NULL);
      i--;
   }
   pthread_join(pid, &retval);
   printf("\nexit\n");
}

void my_thread_func_1()
{
   pthread_mutex_lock(&mutex_t);
   clock_gettime(CLOCK_REALTIME, &waitcount);
   printf("%ld\n", (&waitcount)->tv_sec);
   (&waitcount)->tv_sec += 3;
   pthread_cond_timedwait(&cond_t, &mutex_t, &waitcount);
   printf("%ld\n", (&waitcount)->tv_sec);
   pthread_mutex_unlock(&mutex_t);
}


代码:
jj@hellojinjie:~/mywork/c/linux$ ./pthread_test_timedwait.o1228143386
1228143386
1228143386
1228143386
1228143386
1228143389
1228143389
1228143389
1228143389
1228143389

exit

有半点弄明白了,time用的是绝对时间而不是相对时间,,这点改了

可是输出还不是我想要的啊,,,
pthread_mutex_lock(&mutex_t);好像没有起到作用啊,
我想像的结果应该是这样子的
代码:
1228143386
1228143386
1228143389
1228143386
1228143389
1228143386
1228143389
1228143386
1228143389


_________________
Say hello to everyday!


页首
 用户资料  
 
5 楼 
 文章标题 : Re: 我也在学多线程,pthread_cond_timedwait()有点不懂
帖子发表于 : 2008-12-02 1:18 
头像

注册: 2005-12-28 1:16
帖子: 3916
地址: 火星
系统: Ubuntu 12.10 X64
送出感谢: 1
接收感谢: 0 次
代码:
The  pthread_cond_timedwait() and pthread_cond_wait() functions shall block on a condition variable. They shall be called
       with mutex locked by the calling thread or undefined behavior results.


_________________
目前负债150多万


页首
 用户资料  
 
6 楼 
 文章标题 : Re: 我也在学多线程,pthread_cond_timedwait()有点不懂
帖子发表于 : 2008-12-02 7:32 
头像

注册: 2007-02-18 19:33
帖子: 2180
地址: lyric.im
系统: OSX
送出感谢: 0 次
接收感谢: 1
就知道xhy会进来答


_________________
既然你诚心诚意地问了
我就大慈大悲地告诉你
为了防止世界被破坏
为了维护世界的和平
贯彻爱与真实的罪恶
可爱而又迷人的反派角色
武藏,小次郎
我们是穿越银河的火箭队,白洞白色的明天在等着我们。就是这样!!喵~~


页首
 用户资料  
 
7 楼 
 文章标题 : Re: 我也在学多线程,pthread_cond_timedwait()有点不懂
帖子发表于 : 2008-12-02 8:51 
头像

注册: 2007-09-14 21:03
帖子: 1143
地址: 浙江
送出感谢: 1
接收感谢: 1
呵呵,想明白了,thanks xhy

我所谓的想象的结果是错误的,


_________________
Say hello to everyday!


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 7 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 2 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译