刚开始使用TCP/IP Sockets in C: Practical Guide for Programmers进行C网络连接。我遵循了本书中的代码示例:
#include <stdio.h> //for printf and fprintf
#include <sys/socket.h> // for socket() , connect(),send(), and recv()
#include <arpa/inet.h> //for sockaddr_in and inet_addr()
#include <stdlib.h> //for atoi()
#include <string.h> //for memset()
#include <unistd.h> //for close()
#define RCVBUFSIZE 32 //size of recieve buffer
void DieWithError(char *errorMessage); //error handling function
int main (int argc , char *argv[])
{
int sock; /*SOcket descriptor*/
struct sockaddr_in echoServAddr; /*Echo server address*/
unsigned short echoServPort; /*Echo server port*/
char *servIP; /*Server IP address (dotted quad)*/
char *echoString; /*string to send to echo server*/
char echoBuffer[RCVBUFSIZE]; /*Buffer for echo string*/
unsigned int echoStringLen; /*Length of string to echo*/
int bytesRcvd , totalBytesRcvd; /*Bytes read in single recv() and total bytes read*/
if( (argc < 3) || (argc > 4) ) /*Test for correct number of arguments */
{
fprintf(stderr , "Usage: %s <Server IP> <Echo Word> [<Echo Port>]\n", argv[0]);
exit(1);
}
servIP = argv[1]; /*first arg: server IP address (dotted quad)*/
echoString = argv[2]; /*Second arg: string echo*/
if(argc == 4)
echoServPort = atoi(argv[3]); /*Use given port, if any*/
else
echoServPort = 7; /*7 is the well-known port for the echo service*/
/*Create a reliable, stream socket using TCP*/
if( (sock = socket(PF_INET , SOCK_STREAM , IPPROTO_TCP)) < 0 )
DieWithError("Connect() failed");
/*COnstruct the server address structure*/
memset(&echoServAddr , 0 , sizeof(echoServAddr)); /*zero out structure*/
echoServAddr.sin_family = AF_INET; /*Internet address family*/
echoServAddr.sin_addr.s_addr = inet_addr(servIP); /*Server IP address*/
echoServAddr.sin_port = htons(echoServPort); /*Server port*/
/*Establish the connection the echo server*/
if(connect(sock, (struct sockaddr *) &echoServAddr , sizeof(echoServAddr)) < 0)
DieWithError("send() sent a differnt number of bytes than expected");
/*Recieve the same string back from the server*/
totalBytesRcvd = 0;
printf("Recieved: "); /*setup to print the echoed string*/
while(totalBytesRcvd < echoStringLen)
{
/* Recieve up to the bufffer size (minus 1 to leave space for a null terminator)
bytes from the sender*/
if( (bytesRcvd = recv(sock , echoBuffer , RCVBUFSIZE - 1, 0)) <=0)
DieWithError("recv() failed or connection closed prematurely");
totalBytesRcvd += bytesRcvd; /*Keep tally of total bytes*/
echoBuffer[bytesRcvd] = '\0'; /*Terminate the string*/
printf(echoBuffer); /*Print the echo buffer*/
}
printf("\n"); /*Print a final linefeed*/
close(sock);
exit(0);
}
void DieWithError(char *errorMessage)
{ perror(errorMessage);
exit(1);
}
本书的代码(由于我拥有合法的实物副本,因此无法从本书中复制,但是这里是免费的在线pdf版本的链接)book这是本书中的第一个代码部分
TCPEchoClient.c
然后,这本书告诉我使用以下参数编译和执行程序:
要是我们
编译
这个
应用
如
TCPEchoClient,
我们
能够
通信
与
一个
回声
服务器
与
互联网
地址
169.1.1.1
如
如下:
%TCPEchoClient
169。
一世。一世。
我“回声
这个!”
已收到”
回声
这个!
但是,当我使用本书中的这些参数时,我的程序在运行时就会挂起。我很困惑为什么会这样?任何帮助表示赞赏。
最佳答案
哦,您似乎在复制代码时忘记了一些非常重要的内容:实际上是在向服务器发送内容。
之间的某个地方
if(connect(sock, (struct sockaddr *) &echoServAddr , sizeof(echoServAddr)) < 0)
还有下一行
DieWithError("send() sent a differnt number of bytes than expected");
您似乎缺少将数据发送到服务器的实际代码。
由于不发送任何内容,因此服务器将耐心等待其
recv
调用。同时,您被困在自己的recv
呼叫中,等待从未发生的答复。这导致死锁,服务器和客户端都在等待对方发送东西。