所以,我试图弄清楚C中的套接字库,我遇到了使用recv读取消息的问题。似乎当服务器收到一条消息时,它总是读取8个字符,无论发送的消息或缓冲区大小(只要它的> = 8)。
除此之外,快速连续发送消息使得只有第一条消息通过,是否有一些重置时间并且我不正确地关闭套接字?
到目前为止,这是我的服务器代码:
void main( void ) {
printf( "Starting Server...\n" );
int sock = socket( AF_INET, SOCK_STREAM, 0 );
struct sockaddr_in server, client;
server.sin_family = AF_INET;
server.sin_port = htons( 3030 );
server.sin_addr.s_addr = htonl( INADDR_ANY );
bind( sock, (const struct sockaddr*)&server, sizeof( server ) );
listen( sock, 5 );
while ( 1 ) {
int cli_len = sizeof( client );
int client_socket = accept( sock, (struct sockaddr*)&client, &cli_len );
conn_made( client_socket );
}
}
int conn_made( int client ) {
printf( "Connection Made...\n" );
char *buff = malloc( 1024 );
recv( client, buff, 1024, 0);
int i = 0;
for ( i = 0; i < sizeof( buff ); i++ ) {
printf( "%d byte: %d\n", i, buff[i] );
}
}
答案 0 :(得分:4)
for ( i = 0; i < sizeof( buff ); i++ ) { printf( "%d byte: %d\n", i, buff[i] ); }
那sizeof
完全错了。它将获得您机器上指针的大小(该大小是不变的)。 您应该获得接收的字节数,然后打印它们。
试试这个:
ssize_t sz;
sz = recv(client, buff, 1024, 0);
if (sz < 0) {
perror("recv");
return -1;
}
for (i = 0; i < sz; i++)
printf("%d byte: %d\n", i, buff[i]);