繁体   English   中英

使用C中posix信号量的读写器应用中的分段错误

[英]Segmentation fault in reader-writer appilication using posix semaphore in c

在此代码中,写入器递增数据变量,而读取器打印此数据变量。 任何时候只有一个写入器可以写入,但是当写入器不在数据上写入时,所有读取器都可以打印数据。
附加的代码有时会成功运行,但有时会给出分段错误错误。

读写器代码

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

int reader_count;
int data = 10; /* data on which writer write update & reader read */

/* sem_write: to isolate reader & writer thread */
sem_t sem_write;
/* sem_read: to increment reader counter & sem_write */
sem_t sem_read;


void *writer(void *arg);
void *reader(void *arg);

int main(void)
{
    pthread_t t[10];
    int i = 10;

    if (sem_init(&sem_read, 0, 1)) 
        exit(1);
    if (sem_init(&sem_write, 0, 1)) 
        exit(1);

    /* 5 writer create */
    while (i != 5)
        pthread_create(&t[i--], NULL, writer, NULL);
    /* 5 reader create */
    while (i)
        pthread_create(&t[i--], NULL, reader, NULL);

    /* wait for all threads to completed */
    while (i != 10)
        pthread_join(t[i++], NULL);

    sem_destroy(&sem_read);
    sem_destroy(&sem_write);
    return 0;
}

void *writer(void *arg)
{
    sem_wait(&sem_write);
    sleep(1);   /* writing work */
    data++;
    sem_post(&sem_write);
    pthread_exit(NULL);
}

void *reader(void *arg)
{
    sem_wait(&sem_read);
    reader_count++;
    if (reader_count == 1)
        sem_wait(&sem_write);
    sem_post(&sem_read);

    sleep(1);   /* reading work */
    printf("Data: %d\n", data);

    sem_wait(&sem_read);
    reader_count--;
    if (!reader_count)
        sem_post(&sem_write);
    sem_post(&sem_read);
    pthread_exit(NULL);
}

您访问t[10]越界

int i = 10;
....
 while (i != 5)
    pthread_create(&t[i--], NULL, writer, NULL);

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM