簡體   English   中英

如何阻止pthread從main打印全局變量,然后繼續pthread?

[英]How can I block a pthread to print a global variable from main and then continue the pthread?

我有一個創建pthread的主要功能。 我正在嘗試使用信號量(注意互斥體,s1,s2和memoryUsed全部聲明為全局)在選擇的時間打印全局變量:

int main(int argc, const char * argv[])
{
    pthread_mutex_init(&mutex, NULL);
    sem_init(&s1, 0, 0);
    sem_init(&s2, 0, 0);

    pthread_t t0;
    pthread_create(&t0, NULL, &matrix_management, NULL);

    sem_wait(&s1); // wait for signal from pthread
    printf("Memory Usage from main: %d bytes\n\n", memoryUsed); // global var
    sem_post(&s2); // signal pthread to continue

    pthread_join(t0, NULL);
    sem_destroy(&s1);
    sem_destroy(&s2);
    pthread_mutex_destroy(&mutex);
    return 0;
}

在目標函數中,我想停在一個選擇點,然后從main打印一個全局變量。 注意,該變量在目標函數中已更改。 打印后,我想繼續執行目標功能:

void *matrix_management(void *len)
{
    pthread_mutex_lock(&mutex);

    // CHANGE GLOBAL VAR
    memoryUsed = 1;

    sem_post(&s1); // print from main
    sem_wait(&s2); // wait for signal

    // continue thread...


    pthread_mutex_unlock(&mutex);
    return NULL;
}

但是,主線程似乎根本沒有等待來自pthread的信號。 它立即打印其全局變量的值。 如果我注釋掉pthread中的信號,則程序不會死鎖。 可以像這樣在MAIN線程和pthread之間使用信號量嗎?

根據您的平台,可能不支持未命名的信號燈。 在這種情況下,以下操作將起作用,盡管您可能希望創建臨時名稱,並在以后將其用於取消鏈接。 我熟悉的唯一原因是因為我通常使用的平台OS X不支持10.8.3版中的未命名信號,因此進行無錯誤檢查時,我看到的代碼與您看到的代碼類似,因為所有信號量API失敗。

希望能幫助到你。

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>
#include <semaphore.h>
#include <assert.h>

sem_t* s1=NULL, *s2=NULL;
int memoryUsed = 0;

void *matrix_management(void *len)
{
    // CHANGE GLOBAL VAR
    memoryUsed = 1;

    sem_post(s1); // print from main
    sem_wait(s2); // wait for signal
    printf("Thread woken up.\n");

    // continue thread...
    return NULL;
}

int main(int argc, const char * argv[])
{
    s1 = sem_open("s1", O_CREAT, S_IRUSR | S_IWUSR, 0);
    s2 = sem_open("s2", O_CREAT, S_IRUSR | S_IWUSR, 0);
    assert(s1 && s2 && "Failed to allocate semaphores.");

    pthread_t t0;
    pthread_create(&t0, NULL, &matrix_management, NULL);

    sem_wait(s1); // wait for signal from pthread
    printf("Memory Usage from main: %d bytes.\n", memoryUsed); // global var

    printf("Waking thread...\n"); // global var
    sem_post(s2); // signal pthread to continue

    pthread_join(t0, NULL);
    printf("Thread finished\n");
    sem_close(s1);
    sem_close(s2);
    sem_unlink("s1");
    sem_unlink("s2");
    return 0;
}

輸出量

Memory Usage from main: 1 bytes.
Waking thread...
Thread woken up.
Thread finished

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM