免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1592 | 回复: 4
打印 上一主题 下一主题

select会屏蔽掉stdout吗? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-12 15:35 |只看该作者 |倒序浏览
unp里面的代码,我在第一行加了一句输出,发现不能输出。
莫非printf是有缓存的?
求解,为什么不能输出??有什么方法可以改正?
  1. int
  2. main(int argc, char **argv)
  3. {
  4.         printf("Hello");
  5.         int                                listenfd, connfd, udpfd, nready, maxfdp1;
  6.         char                                mesg[MAXLINE];
  7.         pid_t                                childpid;
  8.         fd_set                        rset;
  9.         ssize_t                        n;
  10.         socklen_t                        len;
  11.         const int                        on = 1;
  12.         struct sockaddr_in        cliaddr, servaddr;
  13.         void                                sig_chld(int);

  14.                 /* 4create listening TCP socket */
  15.         listenfd = Socket(AF_INET, SOCK_STREAM, 0);

  16.         bzero(&servaddr, sizeof(servaddr));
  17.         servaddr.sin_family      = AF_INET;
  18.         servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
  19.         servaddr.sin_port        = htons(SERV_PORT);

  20.         Setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on));
  21.         Bind(listenfd, (SA *) &servaddr, sizeof(servaddr));

  22.         Listen(listenfd, LISTENQ);

  23.                 /* 4create UDP socket */
  24.         udpfd = Socket(AF_INET, SOCK_DGRAM, 0);

  25.         bzero(&servaddr, sizeof(servaddr));
  26.         servaddr.sin_family      = AF_INET;
  27.         servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
  28.         servaddr.sin_port        = htons(SERV_PORT);

  29.         Bind(udpfd, (SA *) &servaddr, sizeof(servaddr));
  30. /* end udpservselect01 */

  31. /* include udpservselect02 */
  32.         Signal(SIGCHLD, sig_chld);        /* must call waitpid() */

  33.         FD_ZERO(&rset);
  34.         maxfdp1 = max(listenfd, udpfd) + 1;
  35.         for ( ; ; ) {
  36.                 FD_SET(listenfd, &rset);
  37.                 FD_SET(udpfd, &rset);
  38.                 if ( (nready = select(maxfdp1, &rset, NULL, NULL, NULL)) < 0) {
  39.                         if (errno == EINTR)
  40.                                 continue;                /* back to for() */
  41.                         else
  42.                                 err_sys("select error");
  43.                 }

  44.                 if (FD_ISSET(listenfd, &rset)) {
  45.                         len = sizeof(cliaddr);
  46.                         connfd = Accept(listenfd, (SA *) &cliaddr, &len);
  47.        
  48.                         if ( (childpid = Fork()) == 0) {        /* child process */
  49.                                 Close(listenfd);        /* close listening socket */
  50.                                 str_echo(connfd);        /* process the request */
  51.                                 exit(0);
  52.                         }
  53.                         Close(connfd);                        /* parent closes connected socket */
  54.                 }

  55.                 if (FD_ISSET(udpfd, &rset)) {
  56.                         len = sizeof(cliaddr);
  57.                         n = Recvfrom(udpfd, mesg, MAXLINE, 0, (SA *) &cliaddr, &len);

  58.                         Sendto(udpfd, mesg, n, 0, (SA *) &cliaddr, len);
  59.                 }
  60.         }
  61. }
复制代码

论坛徽章:
0
2 [报告]
发表于 2010-04-12 16:16 |只看该作者
你只是想调试这段代码,是吗

那你加上回车就可以了

原因是行缓冲

printf("Hello\n");

论坛徽章:
4
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:56:11IT运维版块每日发帖之星
日期:2016-08-11 06:20:00IT运维版块每日发帖之星
日期:2016-08-15 06:20:00
3 [报告]
发表于 2010-04-12 16:53 |只看该作者
楼上正解。
调用printf后,可以用
fflush(stdout);
强制刷新输出。

论坛徽章:
0
4 [报告]
发表于 2010-04-12 17:38 |只看该作者
en
行缓冲

论坛徽章:
0
5 [报告]
发表于 2010-04-12 18:11 |只看该作者
printf("mother fucker");
fflush(stdout);
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP