gpt4 book ai didi

c++ - 线程 - 同步和 sleep 线程拒绝唤醒(LINUX)

转载 作者:塔克拉玛干 更新时间:2023-11-03 08:00:01 26 4
gpt4 key购买 nike

我正在为 OpenSUSE 12.1 开发应用程序。

此应用程序有一个主线程和其他两个运行相同功能实例的线程。我正在尝试使用 pthread_barrier 来同步所有线程,但我遇到了一些问题:

  1. 当我将派生线程置于休眠状态时,它们将永远不会出于某种原因醒来。
  2. (如果我从其他线程中删除 sleep ,将 CPU 使用率抛向天空)在某些时候所有线程都到达 pthread_barrier_wait() 但之后没有一个线程继续执行。

这里有一些伪代码试图说明我在做什么。

pthread_barrier_t barrier;
int main(void)
{
pthread_barrier_init(&barrier, NULL , 3);
pthread_create(&thread_id1, NULL,&thread_func, (void*) &params1);
pthread_create(&thread_id2v, NULL,&thread_func, (void*) &params2);

while(1)
{
doSomeWork();
nanosleep(&t1, &t2);

pthread_barrier_wait(&barrier);

doSomeMoreWork();
}
}

void *thread_func(void *params)
{
init_thread(params);

while(1)
{
nanosleep(&t1, &t2);
doAnotherWork();

pthread_barrier_wait(&barrier);
}
}

最佳答案

我认为这与您在伪代码中介绍的障碍无关。我假设您的 glibc 与我的机器大致相同。我粗略地编译了你的伪代码,它的运行方式与我预期的一样:线程做一些工作,主线程做一些工作,它们都到达障碍然后循环。

您能否评论一下任何其他同步方法或工作函数是什么?

这是我正在使用的示例程序:

#include <pthread.h>
#include <stdio.h>
#include <time.h>

struct timespec req = {1,0}; //{.tv_sec = 1, .tv_nsec = 0};
struct timespec rem = {0,0}; //{.tv_sec = 0, .tv_nsec = 0};

pthread_barrier_t barrier;

void *thread_func(void *params) {
long int name;
name = (long int)params;
while(1) {
printf("This is thread %ld\n", name);
nanosleep(&req, &rem);

pthread_barrier_wait(&barrier);

printf("More work from %ld\n", name);
}
}

int main(void)
{
pthread_t th1, th2;

pthread_barrier_init(&barrier, NULL , 3);
pthread_create(&th1, NULL, &thread_func, (void*)1);
pthread_create(&th2, NULL, &thread_func, (void*)2);

while(1) {
nanosleep(&req, &rem);
printf("This is the parent\n\n");

pthread_barrier_wait(&barrier);
}
return 0;
}

关于c++ - 线程 - 同步和 sleep 线程拒绝唤醒(LINUX),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9997942/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com