为什么我的信号灯无法正常工作?

时间:2019-04-20 16:37:30

标签: c semaphore

我需要在控制台上打印以下句子“我的名字是邦德,詹姆斯·邦德”,并使用信号量交替显示这些单词。

每当我使用换行符“ \ n”打印单词时,所有内容均按预期顺序打印,但是,如果我不使用换行符,则所有内容均按乱序打印。

这是我的代码:

#include <stdio.h>
#include <stdlib.h>
#include <sys/mman.h>
#include <sys/stat.h>
#include <sys/types.h>
#include <fcntl.h>
#include <wait.h>
#include <unistd.h>
#include <semaphore.h>
#include <string.h>

int main(){
    pid_t pid;
    int i = 0;
    sem_t *sem[4];
    char * names[4] = {"/sem_ex07_1", "/sem_ex07_2", "/sem_ex07_3", "/sem_ex07_4"};

    for(i = 0; i < 4; i++){
            sem_unlink(names[i]);
        }

    for(i = 0; i < 4; i++){
        if((sem[i] = sem_open(names[i], O_CREAT | O_EXCL, 0644, 0)) == SEM_FAILED){
            printf("sem_open() error\n");
            sem_unlink(names[i]);
            exit(1);
        }
    }

    sem_post(sem[0]);

    for(i = 0; i < 3; i++){
        pid = fork();
        if(pid == 0){
            break;
        }
    }
    if(pid == 0){
        if(i == 0){

            sem_wait(sem[0]);
            printf("My");
            sem_post(sem[1]);

            sem_wait(sem[0]);
            printf("Bond, ");
            sem_post(sem[1]);
        } else if(i == 1){

            sem_wait(sem[1]);
            printf("name ");
            sem_post(sem[2]);

            sem_wait(sem[1]);
            printf("James ");
            sem_post(sem[2]);
        } else if(i == 2){

            sem_wait(sem[2]);
            printf("is ");
            sem_post(sem[0]);

            sem_wait(sem[2]);
            printf("Bond.\n");
            sem_post(sem[3]);
        }

    } else if(pid > 0){
        sem_wait(sem[3]);

        for(i = 0; i < 4; i++){
            sem_unlink(names[i]);
        }
    }

    return 0;
}

为什么只有在每个printf上添加一个换行符,我的输出才正确?

1 个答案:

答案 0 :(得分:1)

  

为什么只有在每个printf上添加一个换行符,我的输出才正确?

printf()通常默认情况下是行缓冲的。使用流的stdio函数(而不是像write()这样的文件描述符)使用缓冲区。

可以通过setvbuf(3)设置缓冲区。

另请参阅Disable buffering for stdin and stdout using setvbuf()