码迷,mamicode.com
首页 > 其他好文 > 详细

[Chapter11] 由于没加括号导致的bug——调了一个多小时

时间:2020-06-16 13:09:14      阅读:47      评论:0      收藏:0      [点我收藏+]

标签:read   cli   soc   close   错误   mes   打印   sys   amp   

在本章写远程ls程序rls.c和rlsd.c时,while( msglen = read( sock_id, message, BUFSIZ ) > 0 )导致了严重的错误——客户端收到服务器返回的信息,但什么都不打印。

具体代码如下:

/* rls.c - client program of remote ls 
 *      ./rls ubuntu 15000 ‘path‘
 */

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>

int main( int argc, char *argv[] )
/*
 * 1.get a socket
 * 2.set server addr
 * 3.connect server
 * 4.write path to socket stream
 * 5.get message from server
 */
{
    struct sockaddr_in saddr;
    struct hostent *hp;
    int sock_id;
    char message[BUFSIZ];
    int msglen;

    sock_id = socket( AF_INET, SOCK_STREAM, 0 );

    bzero( (void *)&saddr, sizeof(saddr) );
    hp = gethostbyname( argv[1] );
    bcopy( hp->h_addr, (void *)&saddr.sin_addr, hp->h_length );
    saddr.sin_port = htons( atoi(argv[2]) );
    saddr.sin_family = AF_INET;

    connect( sock_id, (struct sockaddr *)&saddr, sizeof(saddr) );

    write( sock_id, argv[3], strlen(argv[3]) );
    write( sock_id, "\n", 1 );

    while( (msglen = read(sock_id, message, BUFSIZ)) > 0 )
        write( 1, message, msglen );

    close( sock_id );
}

 

[Chapter11] 由于没加括号导致的bug——调了一个多小时

标签:read   cli   soc   close   错误   mes   打印   sys   amp   

原文地址:https://www.cnblogs.com/uestcliming666/p/13140154.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!