linux下C语言printf没有输出的问题(shell的行缓冲机制)

    while(true)
    {
        if(recvfrom(sockfd,buf, sizeof(buf), 0, (struct sockaddr*)&src_addr, &len) == -1)
        {
            perror("receive failed\n");
            return -1;
        }
        printf("%s----from %s:%u\n", buf, inet_ntoa(src_addr.sin_addr), ntohl(src_addr.sin_port));
    }

这个是udp编程中接收端的程序的一部分,但是你会发现printf没有输出,用gdb调试,发现程序是正常跑的,这是因为shell是存在行缓冲的(每次攒够一行(出现换行符))才会输出,所以这里在printf的末尾加上\n就可以正常输出了

以下是一个简易的shell程序,可以在Linux下用C语言编写: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/wait.h> #define MAX_LINE 80 /* 命令最大长度 */ int main(void) { char *args[MAX_LINE / 2 + 1]; /* 命令参数 */ char input[MAX_LINE + 1]; /* 命令输入 */ int should_run = 1; /* 判断是否退出shell */ pid_t pid; /* 进程ID */ while (should_run) { printf("osh> "); fflush(stdout); /* 刷新输出缓冲区 */ fgets(input, MAX_LINE, stdin); /* 读取命令输入 */ /* 将输入字符串拆分为参数数组 */ char *token; int i = 0; token = strtok(input, " \n"); while (token != NULL) { args[i++] = token; token = strtok(NULL, " \n"); } args[i] = NULL; /* 参数数组以NULL结尾 */ /* 检查是否退出shell */ if (strcmp(args[0], "exit") == 0) { should_run = 0; continue; } /* 创建子进程执命令 */ pid = fork(); if (pid < 0) /* 创建进程失败 */ { fprintf(stderr, "fork failed\n"); return 1; } else if (pid == 0) /* 子进程 */ { execvp(args[0], args); /* 执命令 */ fprintf(stderr, "execvp failed\n"); /* 如果execvp返回,则表示执失败 */ return 1; } else /* 父进程 */ { wait(NULL); /* 等待子进程结束 */ } } return 0; } ``` 该程序的基本思路是每次读取一命令输入,将输入字符串拆分为参数数组,然后创建一个子进程执命令,等待子进程结束后再读取下一输入。如果输入的第一个参数是“exit”,则退出程序。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值