因此,我试图找出 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] );
}
}
最佳答案
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]);
关于c - Recv一次只能获取8个字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9144153/