首页 新闻 会员 周边 捐助

关于pthread_mutex多个线程忙等待问题?

0
悬赏园豆:100 [已解决问题] 解决于 2021-11-23 14:08

文档说如果对一个已加锁的mutex再次加锁pthread_mutex_lock会形成一个等待队列。可是这个示例有点奇怪,我知道线程没有放弃cpu,可是为什么后面输出的hello不到数量?

ifndef THREAD_POOL_H

define THREAD_POOL_H

include <pthread.h>

include <errno.h>

include <iostream>

include <unistd.h>

include <queue>

class sample
{
public:
void process();
};

template <typename T>
class threadPool
{
public:
threadPool();
void append(T &s);
static void worker(void s);

private:
std::queue<T *> tasks;
pthread_t threads[5];
bool run = true;
pthread_mutex_t t;
};

// template <typename T>
// void threadPool<T>::append(T& s)
// {
// pthread_t t;
// pthread_create(&t,nullptr,worker,&s);
// pthread_detach(t);
// }
template <typename T>
threadPool<T>::threadPool() : tasks()
{
pthread_mutex_init(&t,nullptr);
for(int i=0;i<5;++i)
{
pthread_create(&threads[i],nullptr,worker,this);
pthread_detach(threads[i]);
}
}

template <typename T>
void threadPool<T>::append(T &s)
{
pthread_mutex_lock(&t);
tasks.push(&s);
printf("%d append.\n",pthread_self());
pthread_mutex_unlock(&t);
}

template <typename T>
void threadPool<T>::worker(void s)
{
auto pool=static_cast<threadPool<T>*>(s);
while (pool->run)
{
pthread_mutex_lock(&(pool->t));
if (pool->tasks.empty())
{
pthread_mutex_unlock(&(pool->t));
printf("%d get the lock but continue.\n",pthread_self());
continue;
}
auto work = pool->tasks.front();
pool->tasks.pop();
printf("%d get the lock and print\n",pthread_self());
pthread_mutex_unlock(&(pool->t));
work->process();
}
return nullptr;
}

endif //!THREAD_POOL_H

include "thread_pool.h"

void sample::process()
{
std::cout<<"hello world.\n"<<std::endl;
}

include "thread_pool.h"

include <iostream>

int main(int argc, char **argv)
{
threadPool<sample> pool;
sample d[100];
for(int i=0;i<100;++i)
{
pool.append(d[i]);
}
return 0;
}
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1268307712 get the lock but continue.
1285158720 append.
1268307712 get the lock and print
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1243129600 get the lock but continue.
1259915008 get the lock but continue.
1251522304 get the lock but continue.
hello world.
1285158720 append.

1268307712 get the lock and print
hello world.

1268307712 get the lock but continue.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1251522304 get the lock and print
hello world.

1251522304 get the lock and print
hello world.
1259915008 get the lock and print

1243129600 get the lock and print
hello world.

1243129600 get the lock and print
hello world.

1243129600 get the lock and print
hello world.

1243129600 get the lock and print
hello world.

1243129600 get the lock and print
hello world.
1285158720 append.
1251522304 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1285158720 append.
1234736896 get the lock and print
hello world.

1259915008 get the lock and print
hello world.

1259915008 get the lock and print
hello world.

1259915008 get the lock and print
hello world.
hello world.

1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1251522304 get the lock and print
hello world.

1251522304 get the lock and print
hello world.

1251522304 get the lock and print
hello world.

1251522304 get the lock and print
hello world.

1251522304 get the lock and print
hello world.

1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1251522304 get the lock but continue.
1268307712 get the lock but continue.
1259915008 get the lock but continue.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1234736896 get the lock and print
hello world.

1234736896 get the lock and print
hello world.

1243129600 get the lock and print
hello world.

1243129600 get the lock and print
hello world.

1243129600 get the lock and print
hello world.

1243129600 get the lock and print
hello world.

1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1243129600 get the lock but continue.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.
1285158720 append.

头晕了一下午,麻烦大佬出来解救众生。

manch1n的主页 manch1n | 初学一级 | 园豆:86
提问于:2019-05-12 01:02
< >
分享
最佳答案
0

main函数已经退出了,其他打印都看不到了
main末尾加个 getchar() 或者同步等待下

收获园豆:100
2012 | 高人七级 |园豆:21645 | 2019-05-13 09:00
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册