gpt4 book ai didi

c - 全局变量不会在c中的其他线程中改变

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:54:32 26 4
gpt4 key购买 nike

我在c程序中有一个全局变量,我的环境是linux。当我在主线程中更改我的全局变量时,我看到更改是正确的,但在其他线程中没有任何反应。我的全局在 .h 文件中声明,.c 是相同的文件名。但是,如果我在另一个线程中更改全局,则其他线程也会更改。我已经打印了全局变量的内存,在主线程和其他线程中都是一样的。下面是我的代码示例。

int pause_flag;

int initThread() {
int err;

err = pthread_create(&user_request_thread, NULL, (void *)&user_request_handler, NULL);
if (err != 0)
return(EXIT_FAILURE);

printLog("Agent-Less service", "start...");

closelog();
pthread_join(user_request_thread, NULL);
pthread_detach(user_request_thread);

return(EXIT_SUCCESS);
}

int pause() {
setPauseFlag(1);

return EXIT_SUCCESS;
}

void user_request_handler(void *arg) {
while (1) {
printf("pause_flag %d\n", getPauseFlag());
sleep(5);
}
pthread_exit(0);
}
void setPauseFlag(int value) {
pthread_mutex_lock(&pause_lock);
pause_flag = value;
pthread_mutex_unlock(&pause_lock);
}

int getPauseFlag() {
int temp;

pthread_mutex_lock(&pause_lock);
temp = pause_flag;
pthread_mutex_unlock(&pause_lock);

return temp;;
}

最佳答案

在多核系统上,即使是volatile也不足以保证线程间的同步。 volatile 将强制写入底层硬件,这可能是某些外围芯片中的硬件寄存器,或者只是 DRAM 中的一个位置。但它不一定会在不同的处理器核心上更新变量,如果另一个核心有变量的缓存副本。换句话说,volatile 不会强制跨多个处理器核心的缓存一致性。

要强制更新保证在所有内核上的所有线程中可见的变量,您需要使用内核的同步机制之一,例如一个信号量。

http://en.wikipedia.org/wiki/Memory_barrier

另请参阅 pat 在评论中提供的链接。

get 函数的代码应该如下所示

int getPauseFlag()
{
int temp;

pthread_mutex_lock(&pause_lock);
temp = pause_flag;
pthread_mutex_unlock(&pause_lock);

return temp;
}

关于c - 全局变量不会在c中的其他线程中改变,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22469233/

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