网友您好, 请在下方输入框内输入要搜索的题目:

题目内容 (请给出正确答案)

如何用套接字完成一个客户机/服务器的通信?


参考答案

更多 “如何用套接字完成一个客户机/服务器的通信?” 相关考题
考题 (56) MSN、ICQ、AIM和Yahoo Messenger等主流即时通信软件的文本消息多使用( )模式。A)客户机/客户机B)客户机/服务器C)服务器/客户机D)服务器/服务器

考题 ● 试题四请阅读以下说明和Socfort程序,将应填(n)处的字句写在答题纸的对应栏内。【说明】网络应用的基本模型是客户机/服务器模型,这是一个不对称的编程模型,通信的双方扮演不同的角色:客户机和服务器。以下是一个简单的客户机程序(服务器程序略),其工作过程非常简单:客户机与服务器建立连接后,接收服务器向客户机返回的一条消息。程序中用到了两种结构hostent与sockaddr_in:hostent类型的结构定义如下:struct hostent { char*h_name;//主机的正式名称char**h_aliases;//别名列表int h_addrtype;//主机地址类型:AF-XXXint H_length;//主机地址长度:4 B(32 b)char**h_addr_list;//主机IP地址列表}#define h-addr h-addr-list[0]sockaddr_in类型的结构定义:sockaddr_in是通用套接字结构sockaddr在TCP/IP协议下的结构重定义,为TCP/IP套接字地址结构。Struct sockaddrin{short int sin-family;//地址类型AF_XXX,其中AF_INET为TCP/IP专用unsigned short int sin-port;//端口号struct in_addr sin_addr;//Internet地址//端口号以及Internet地址使用的是网络字节顺序,需要通过函数htons转换}struct iN_addr{_u32 s-addr;//类型为unsignel-long}程序中使用到了多个函数:struct hostent * gethostbyname(const char* hostname);函数gethostbyname查询与指定的域名地址对应的IP地址,返回一个hostent结构的指针,如果不成功则返回NULL。int_socket(int domain,im-type,int protoco1);函数socket创建一个套接字描述符,如果失败返回-1。domain为地址类型,type为套接字类型,本题中为SOCK_STREAM;protocol指定协议,本题中为0。int connect(int sockfd,struct sockaddr* servaddr,int addrlen);函数connect与服务器建立一个连接,成功返回0,失败返回-1。servaddr为远程服务器的套接字地址,包括服务器的IP地址和端口号;addrlen为地址的长度。int read(int fd,char*bur,int len);int write(int fd,char*buf,int len);函数read和write从套接字读和写数据,成功返回数据量大小,否则返回-1。buf指定数据缓冲区,len指定接收或发送的数据量大小。【Socket程序】//程序中引用的头文件略#definePORT 3490//定义端口号为3490int main(int argc,char*argv[]){int sockfd,nbytes;//套接字描述符、读入缓冲区的字节数char buf[1024];//缓冲区struct hostent*he;//主机信息类型struct (1) srvaddr;//Internet套接字结构if(argc!=2){perror("调用参数为零,请输入服务器的主机名!\n");exit (1) ;}if( (2) )//如果通过主机名没有获得对应的主机信息就提示用户{perror("无法通过主机名获得主机信息!\n");exit (1) ;}if( (3) ) //在无法创建套接字时,提示用户{perror("无法创建套按字!\n");exit (1) ;}bzero(srvaddr, (4) );//置空srvaddrsraddr,sin_family=AF_INET;srvaddr,sin_port: htons(PORT);srvaddr.sin_addr: (5) ;//设置套接字结构的各项信息,其中的地址来自域名查询后的hp变量if(connect(sockfd,(n) ,sizeof(struct sockaddr))==-1){perror("连接失败!\n");exit (1) ;}//连接服务器,如果失败则提示用户if((nbytes=read(sockfd,buf,MAXDATASIZE))=-1){perror("读失败!\n");exit (1) ;}//从套接字中读出数据buf[nbytes]=\0;printf("读到的内容:%s",buf);close(sockfd);//打印数据并关闭套接字}

考题 ● 试题二请阅读以下说明和Socket程序,将应填入(n)处的字句写在答题纸的对应栏内。【说明】网络应用的基本模型是客户机/服务器模型,这是一个不对称的编程模型,通信的双方扮演不同的角色:客户机和服务器。一般发起通信请求的应用程序称为客户软件,该应用程序通过与服务器进程建立连接,发送请求,然后等待服务器返回所请求的内容。服务器软件一般是指等待接收并处理客户机请求的应用程序,通常由系统执行,等待客户机请求,并且在接收到请求之后,根据请求的内容,向客户机返回合适的内容。本题中的程序较为简单,客户机接收用户在键盘上输入的文字内容,服务器将客户机发送来的文字内容直接返回给客户机,在通信过程中服务器方和客户机方都遵守的通信协议如下:由客户机首先发送请求,该请求由首部和内容两大部分组成,两个部分各占一行文字,通过行结束符"\n"隔离。首部只有一个Length域,用于指定请求的内容部分的长度,首部的结构为:"关键词Length"+""+数值+"\n"。内容部分为一行文字,其长度必须与Length域的数值相符例如,客户机的请求为"Length 14\nHello,my baby!",服务器接收请求处理后返回文字"Hello,my baby!"。【Socket程序】服务器主程序部分:#includestdio.h……//引用头文件部分略#define SERVER_PORT 8080//服务器监听端口号为8080#define BACKLOG 5/连接请求队列长度int main(int argc,char * argv[]){int listenfd,connfd//监听套接字、连接套接字描述符struct sockaddr_in servaddr;//服务器监听地址listenfd= (1) ;//创建用于监听的套接字if(listenfd0){fprintf(stderr,"创建套接字错误!")exit (1) ;}//套接字创建失败时打印错误信息bzero(servaddr.sizeof(servadd));//将地址结构置空servaddr.sin_family=AF_INET;//设置地址结构遵循TCP/IP协议servaddr.sin_addrs_addr=htonl. (2) ;//设置监听的IP地址为任意合法地址,并将该地址转换为网络字节顺序servaddr.sin_port= (3) ;//设置监听的端口,并转化为网络字节顺序if(bind (4) 0){fprintf(stderr,"绑定套接字与地址!");exit (1) ;}//将监听地址与用于监听的套接字绑定,绑定失败时打印错误信息if(listen(listedfd,BACKLOG)0){fprintf(stderr,转换套接字为监听套接字!");exit (1) ;}//将用于监听的套接字由普通套接字转化为监听套接字for(;;){connfd= (5) ;//从监听套接字的连接队列中接收已经完成的连接,并创建新的连接套接字if(connfd0){fprintf(stderr,"接收连接失败!");exit (1) ;}//接收失败打印错误信息serv_respon(connfd);//运行服务器的处理函数close(connfd);//关闭连接套接字}dose(listenfd);//关闭监听套接字}服务器通信部分:#includestdio.h ……//引用头文件部分略void serv_respon(int sockfd){int nbytes;char bur[1024];for(;;){nbytes=read_requ(sockfd,bur,1024);//读出客户机发出的请求,并分析其中的协议结构,获知请求的内容部分的长度,并将内容复制到缓冲区buf中,if( (6) )return;//如客户机结束发送就退出else if(bytes0){fprintf(siderr,"读错误情息:%s\n",strerror(errno));return;} //读请求错误打印错误信息if(write-all(sockfd,buf,nbytes)0)//将请求中的内容部分反向发送回客户机fprintf(siderr,"写错误信息:%s\n",strerror(errno));}}int read_requ(int sockfd,char*buf int size){char inbuf[256];int n;int i;i=read_line(sockfd,inbuf,256);//从套接字接收缓冲区中读出一行数据,该数据为客户请求的首部if(1O)return(i);else if(i==0)return(0);if(stmcmp(inbuf,″″,6)==0)scanf( (7) ,″%d″,n); //从缓冲区buf中读出长度信息else{sprintf(bur,″″,14);return (14) ;} //取出首部Length域中的数值,该数值为内容部分的长度return(read-all(sockfd,bur,n));//从接收缓冲区中读出请求的内容部分}int get-char(int fd,char*ch){static int ffset=0;static int size=0;static char buff[1024];//声明静态变量,在get_char多次被调用期间,该变量的内存不释放for(;size=0 | | (8) ;){size=read(fd,bur,1024);//一次从套接字缓冲区中读出一个数据块if(size0){if(errno==EINTR){size=0;contine;//EINTR表示本次读操作没有成功,但可以继续使用该套接字读出数i}elsereturn(-1);}offset=0; //读出数据后,将偏址置为0*ch=buf[offset ++]; //将当前的字符取出,并将偏址移向下一字符return (1) ;}int read _ line(int fd,char*buf,int msxlen){int i, n;char ch;for(i=0;i (9) ){n=get_char(fd,ch);//取出一个字符if(n==1){buff[i++]=ch;//将字符加入字符串中if( (10) )break;}else if(n)return(-1);else break;}buf[i]=`\0`;return(i);}//函数read_line的作用是读出请求的首部,其处理的方法是每次调用get_char函数,取出一个字符,检查该字符是否是回车符`\n`,如果是回车符,就返回请求的首部//get_char的处理方式较为特殊,并不是每次调用read函数读一个字符,而是一次从缓冲区中读一块内容,再一次一个字符提交给函数read_line,如果提交完了就再读一块,这样就可以提高读缓冲区的效率。另外,由于客户机是分两次调用writ_all函数将请求的首部和内容发送给服务器,因此get_char不会取出请求内容部分的字符部分SOCKET数据结构与函数:1.地址结构。sockaddr-in:sockaddr_in类型的结构定义,sockaddr_in是通用套接字结构sockaddr在TCP/IP协议下的结构重定义,为TCP/IP套接字地址结构。Struct sockaddr_in{short int sin_family;//地址类型AF_XXX,其中AF_INET为TCP/IP专用unsigned short int sin _port;//端口号struct in_addr sin_addr;//Internet地址//端口号以及Internet地址使用的是网络字节顺序,需要通过函数htons转换}struct_inaddr{_u32 s_addr;//类型为unsignel long}hostent:hostent类型的结构定义struct hostnet{char*h_name;//主机的正式名称char**h_aliases;//别名列表nit h_addrtvPe;//主机地址类型:AF_XXXint h_length;//主机地址长度:4字节(32位)char**h_addr_list;//主机IP地址列表}#define h_addr h_addr_list[0]2.基本函数。int socket(int domain,int type,int protocol);函数socket创建一个套接字描述符,如果失败则返回-1。domain为地址类型,type为套接字类型,本题中为SOCK_STREAM;protocol指定协议,本题中为0。int connect(int sockfd,struct sockaddr*servaddr,int addrlen);函数connect与服务器建立一个连接,成功返回0,失败返回-1。servaddr为远程服务器的套接字地址,包括服务器的IP地址和端口号;addrlen为地址的长度。int read(int fd,char*bur,int len);int write(int fd,char*buf,int len);函数read和write从套接字读和写数据,成功返回数据量大小,否则返回-1。buf指定数据缓冲区,len指定接收或发送的数据量大小。int bind(int sockfd,struct sockaddr*myaddr,int addrlen);函数bind将本地地址与套接字绑定在一起,成功返回0,否则返回-1;myaddr是本机地址;addrlen为套接字地址结构的长度。int listen(int sockfd,int backlog);函数listen将一个套接字转换为倾听套接字,成功返回0,否则返回-1;backlog为请求队列的最大长度。int accept(int sockfd,struct sockaddr*addr,int*addrlen);函数accept从倾听套接字的完成连接中接收一个连接,如果完成连接队列为空,那么这个进程睡眠,失败时返回-1,成功时返回新的套接字描述符。Sockfd为倾听套接字,addr为客户机的地址,addlen为地址长度,在调用时用常量NULL代替addr与addlen表示无须取出客户机的地址信息struct hostent *gethostbyname(const char*hostname);函数gethostbyname查询指定的域名地址对应的IP地址,返回一个hostent结构的指针,如果不成功返回NULL。3.用户自定义函数。int read_all(int fd,void*bur,int nbyte);函数read all从参数fd指定的套接字描述符中读取nbytes字节数据至缓冲区buf中,成功返回实际读的字节数(可能小于nbyte),失败返回-1。int write_all(int fd,void*bur,int nbyte);函数write_all向参数fd指定的套接字描述符中写入缓冲区buf前nbyte字节的数据,成功返回实际写的字节数(始终等于nbyte),失败返回-1。write_requ函数为客户机发送请求的函数;read_requ函数为服务器获取请求的函数。

考题 ●Socket的通信方式包括 (62) , (63) 是最常用的套接字类型。(62)、(63) A.字节流套接字B.数据报套接字C.原始数据报套接字D.A、B和C

考题 请阅读以下说明和Socket程序,填入(n)处。网络应用的基本模型是客户机/服务器模型,这是一个不对称的编程模型,通信的双方扮演不同的角色:客户机和服务器。本题中的程序,客户机接收用户在键盘上输入的文字内容,服务器将客户机发送来的文字内容直接返回给客户机。此程序中,用户自定义函数有:int read_all( int fd, void*buf, int nbyte );函数read all从参数fd指定的套接字描述符中读取nbytes字节数据至缓冲区buf中,成功返回实际读的字节数(可能小于nbyte),失败返回-1。int write_all( int fd, void*buf, int nbyte );函数write_all向参数fd指定的套接字描述符中写入缓冲区buf前nbyte字节的数据,成功返回实际写的字节数(始终等于nbyte),失败返回-1。write_requ函数为客户机发送请求的函数;read_requ函数为服务器获取请求的函数服务器主程序部分:define SERVER_PORT 8080 //服务器监听端口号为8080define BACKLOG 5 //连接请求队列长度int main( int argc, char*argv[]) {int listenfd, connfd //监听套接字、连接套接字描述符struct sockaddr_in servaddr; //服务器监听地址listenfd=(1); //创建用于监听的套接字if (listenfd<0) {fPrintf( stderr,"创建套接字错误!");exit(1);} //套接字创建失败时打印错误信息bzero(servaddr.sizeof(servadd));//将地址结构置空servaddr.sin_family=AF_INET;//设置地址结构遵循TCP/IP协议servaddr.sin_addrs_addr=htonl.(2);//设置监听的IP地址为任意合法地址,并将该地址转换为网络字节顺序servaddr.sin_port=(3);//设置监听的端口,并转化为网络字节顺序if ( bind(4)<0 ) {fprintf( stderr,"绑定套接字与地址!");exit(1);} //将监听地址与用于监听的套接字绑定,绑定失败时打印错误信息if ( listen( listedfd, BACKLOG)<0) {fprintf( stderr,"转换套接字为监听套接字!");exit(1);} //将用于监听的套接字由普通套接字转化为监听套接字for(;){connfd=(5);//从监听套接字的连接队列中接收已经完成的连接,并创建新的连接套接字if(connfd<0){fprintf(stderr,"接收连接失败!");exit(1);} //接收失败打印错误信息serv_respon(connfd); //运行服务器的处理函数(6);//关闭连接套接字 }close(listenfd);//关闭监听套接字 }服务器通信部分:include<stdio.h>……//引用头文件部分略>void serv_respon( int sockfd) {int nbytes; char buf[1024];for(;;) {nbytes=read_requ(sockfd, buf, 1024);//读出客户机发出的请求,并分析其中的协议结构,获知请求的内容部分的长度,并将内容复制到缓冲区buf中,if ( nbytes=0) return;//如客户机结束发送就退出else if ( bytes<0 ) {fprintf( siderr,"读错误情息:%s\n", sterror( errno ));return;}//读请求错误打印错误信息if ( write_all ( sockfd, buf, nbytes)<0)//将请求中的内容部分反向发送回客户机fprintf( siderr,"写错误信息:%s\n", strerror( errno ) );}}int read_requ( int sockfd, char*buf int size ) {char inbuf[256];int n; int i;i=read_line( sockfd, inbuf, 256 );//从套接字接收缓冲区中读出一行数据,该数据为客户请求的首部if(1<O)return(1);else if ( i=0 ) return(0);if ( strncmp( inbuf,"",6 )=0)sscanf( (7),"%d", n );//从缓冲区buf中读出长度信息else{sprintf( buf," ",14 );return(14);}//取出首部Length域中的数值,该数值为内容部分的长度return( read_all( sockfd, buf, n ) );//从接收缓冲区中读出请求的内容部分}int get_char(int fd, char*ch) {static int ffset=0;static int size=0;static char buff[1024];//声明静态变量,在get_char多次被调用期间,该变量的内存不释放for ( ;size<=0 ||(8);) {size=read(fd,buf,1024);//一次从套接字缓冲区中读出一个数据块if ( size<0 ) {if ( errno=EINTR ) {size=0;confine;//EINTR表示本次读操作没有成功,但可以继续使用该套接字读出数i}elsereturn(-1);}ffset=0;//读出数据后,将偏址置为0}*ch=buf[(9)];//将当前的字符取出,并将偏址移向下一字符return(1);}int read_line(int fd, char*buf, int maxlen) {int i,n;char ch;for ( i=0; i<maxlen;) {n = get_char( fd, ch );//取出一个字符if ( n==1 ){buff[i++]=ch;//将字符加入字符串中if ( (10) break;}else if ( n< ) return(-1);else break;}buf[i]='\0';return(i);}//函数read_line的作用

考题 请阅读以下说明和Socket程序,将应填入(n)处的字句写在对应栏内。网络应用的基本模型是客户机/服务器模型,这是一个不对称的编程模型,通信的双方扮演不同的角色:客户机和服务器。一般发起通信请求的应用程序称为客户软件,该应用程序通过与服务器进程建立连接,发送请求,然后等待服务器返回所请求的,内容。服务器软件一般是指等待接收并处理客户机请求的应用程序,通常由系统执行,等待客户机请求,并且在接收到请求之后,根据请求的内容,向客户机返回合适的内容。本题中的程序较为简单,客户机接收用户在键盘上输入的文字内容,服务器将客户机发送来的文字内容直接返回给客户机,在通信过程中服务器方和客户机方都遵守的通信协议如下:由客户机首先发送请求,该请求由首部和内容两大部分组成,两个部分各占一行文字,通过行结束符“\n”隔离。首部只有一个Length域,用于指定请求的内容部分的长度,首部的结构为:“关键词 Iength”+“”+数值+“\n”。内容部分为一行文字,其长度必须与Length域的数值相符例如,客户机的请求为“Length 14\nilello,mybaby!”,服务器接收请求处理后返回文字“Hello,my babv!”。[Socket程序]服务器主程序部分:include<stdio.h……/引用头文件部分略define SERVER_PORT 8080//服务器监听端口号为8080define BACKLOG 5 /连接请求队列长度int main(int argc,char *a rgv[]){int listenfd,connfd//监听套接字、连接套接字描述符struct sockaddr_in servaddr;//服务器监听地址listenfd=(1);//创建用于监听的套接字if(1istenfd<0){fprintf(stderr,"创建套接字错误!")exit(1);} //套接字创建失败时打印错误信息bzero(servaddr. sizeof(servadd));//将地址结构置空servaddr.sin_family=AF_INET;//设置地址结构遵循TCP/IP协议servaddr.sln_addrs_addr=htonl. (2);//设置监听的IP地址为任意合法地址,并将该地址转换为网络字节顺序servaddr.sin_port=(3);//设置监听的端口,并转化为网络字节顺序if(bind (4)<0){fprintf(stderr,”绑定套接字与地址!”);exit(1);} //将监听地址与用于监听的套接字绑定,绑定失败时打印错误信息if(listen(listedfd,BACKlOG)<0){fprintf(stderr,“转换套接字为监听套接字!”);exit(1);} //将用于监听的套接字由普通套接字转化为监听套接字for(;;){connfd=(5);//从监听套接字的连接队列中接收已经完成的连接,并创建新的连接套接字if(connfd<0){fprintf(Stderr,"接收连接失败!");exit(1);} //接收失败打印错误信息serv_respon(connfd);//运行服务器的处理函数close(connfd);//关闭连接套接字}dose(listenfd); //关闭监听套接字}服务器通信部分:include……//引用头文件部分略Void serv_respon(int sockfd){Int nbytes;char bur[1024];for(;;){nbytes=read_requ(Sockfd,bUr,1024);//读出客户机发出的请求,并分析其中的协议结构,获知请求的内容部分的长度,并将内容复制到缓冲区buf中,if( (6) )return;//如客户机结束发送就退出else if(bytes<0){fprintf(Siderr,"读错误情息:%S\n",strerror(errno));return;}//读请求错误打印错误信息if(wnte-all(sockfd,buf,nbytes)<0)//将请求中的内容部分反向发送回客户机fprintf(siderr,"写错误信息:%s\n",strerror(errno));}}int read_requ(int sockfd,char * buf int size){Char inbuf[256];int n;int i;i=read_line(sockfd,inbUf,256);//从套接字接收缓冲区中读出一行数据,该数据为客户请求的首部if(1<O)return(i);else if(i==0)return(0);if(stmcmp(inbu,"",6)==0)scanf((7),"%d",n);//从缓冲区buf中读出长度信息else{sprintf(bur,"",14);return(14);}//取出首部Length域中的数值,该数值为内容部分的长度return(read-all(sockfd,bur,n));//从接收缓冲区中读出请求的内容部分}int get-char(int fd,char * ch){static int offset=0;static int size=0;static char buff[1024];//声明静态变量,在get_char多次被调用期间,该变量的内存不释放for(;size<=0 ||(8);){size=read(fd,bur,1024);//一次从套接字缓冲区中读出一个数据块if(size<0){if(errno==EINTR){size=0;contine;//EINT日表示本次读操作没有成功,但可以继续使用该套接字读出数i}elsereturn(-1);}offset=0;//读出数据后,将偏址置为0*ch:buf[offset++);//将当前的字符取出,并将偏址移向下一字符return(1);}int read_line(int fd,char * buf,int msxlen){int i, n;Char ch;for(i=0;i<(9)){n=get_char(fd,ch);//取出一个字符if(n==1){buff[i++]=ch//将字符加入字符串中if( (10) )break;}else if(n<)return(-1);else break;}buf[i]='\0';return(i);}

考题 socket调用需要客户程序和服务器程序分别调用才能建立一个套接字连接()

考题 在利用socket编写邮件服务器时,使用的套接字应该是()。 A.流式套接字B.数据报套接字C.UDP套接字D.TCP套接字

考题 在面向连接的套接字编程中,服务器端必须执行的一个独特函数是( )。 A.listenB.connectC.recvD.send

考题 因特网的主要组成部分包括______。A.通信线路、路由器、服务器和客户机信息资源B.客户机与服务器、信息资源、电话线路、卫星通信C.卫星通信、电话线路、客户机与服务器、路由器D.通信线路、路由器、TCP/IP协议、客户机与服务器

考题 请阅读以下说明和Socfort程序,将应填(n)处的字句写在对应栏内。网络应用的基本模型是客户机/服务器模型,这是一个不对称的编程模型,通信的双方扮演不同的角色:客户机和服务器。以下是一个简单的客户机程序(服务器程序略),其工作过程非常简单:客户机与服务器建立连接后,接收服务器向客户机返回的一条消息。程序中用到了两种结构hostent与sockaddr_in:hostent类型的结构定义如下:struct hostent { char * h_name; //主机的正式名称char * * h-aliases; //别名列表int h_addrtype; //主机地址类型:AF-XXXint H_length; //主机地址长度:4 B(32 b)char * * h_addr_list; //主机IP地址列表}define h???-addr h-addr-liSt[0]sockaddr_in类型的结构定义:sockaddr_in是通用套接字结构sockaddr在TCP/IP协议下的结构重定义,为TCP/IP套接字地址结构。Struct sockaddrin{short int sin-family;//地址类型AF_XXX,其中AF_INET为TCP/P专用unsigned short int sin-port; //端口号struct in_addr Sin_addr; //Internet地址//端口号以及Internet地址使用的是网络字节顺序,需要通过函数htons转换}struct iN_addr{_u32 s-addr; //类型为unsignel-long}程序中使用到了多个函数:struct hostent * gethostbyname(const char * hostname);函数gethostbyname查询与指定的域名地址对应的IP地址,返回一个hostent结构的指针,如果不成功则返回NULL。Int?_socket(int domain,im-type,int protoco1);函数socket创建一个套接字描述符,如果失败返回-1。domain为地址类型,type为套接字类型,本题中为SOCK_STREAM;protocol指定协议,本题中为0。int connect(int sockfd,struct sockaddr * servaddr,int addrlen);函数connect与服务器建立一个连接,成功返回0,失败返回-1。servaddr为远程服务器的套接字地址,包括服务器的IP地址和端口号;addrlen为地址的长度。int read(intfd,char * bur,int len);int write(intfd,char * buf,int len);函数read和write从套接字读和写数据,成功返回数据量大小,否则返回-1。buf指定数据缓冲区,len指定接收或发送的数据量大小。[Socket程序]//程序中引用的头丈件略definePORT 3490//定,义端口号为3490int main(int argc,char * argv[]){int tsockfd,nbytes;//套接字描述符、读入缓冲区的字节数char buf[1024];//缓冲区struct hostent * he;//主机信息类型struct (1) srvadd;//Internet套接字结构if(argc!=2){perror(“调用参数为零,请输入服务器的主机名!\n”);exit(1);}if((2))//如果通过主机名没有获得对应的主机信息就提示用户{perror(“无法通过主机名获得主机信息!\n”);exit(1);}if((3))//在无法创建套接字时,提示用户{perror(“无法创建套按字!\n”);exit(1);}bzero(srvaddr, (4));//置空srvaddrsraddr,SIR_family=AF_INET;srvaddr,sln_port:htons(PO日T);srvaddr.sin_addr: (5);//设置套接字结构的各项信息,其中的地址来自域名查询后的hp变量if(connect(sockfd,(n),sizeof(struct sockaddr))==-1){perror("连接失败!\n");exit(1);}//连接服务器,如果失败则提示用户if((nbytes=read(sockfd,buf,MAXDATASIZE))=-1){perror("读失败!\n");exit(1);}//从套接字中读出数据buf[nbytes]='\0';printf("读到的内容:%s",buf);CIose(SOCkfd);//打印数据并关闭套接字

考题 MSN、ICQ、AIM和Yahoo Messenger等主流即时通信软件的文本消息多使用( )模式。A.客户机/客户机B.客户机/服务器C.服务器/客户机D.服务器/服务器

考题 Socket的通信方式包括(62),(63)是最常用的套接字类型。A.字节流套接字B.数据报套接字C.原始数据报套接字D.A、B和C

考题 支持双向的数据流,但并不保证是可靠、有序、无重复的是()。 A.流套接字B.数据报套接字C.客户端套接字D.服务器端套接字

考题 根据下面的文字资料回答 11~12 题 Socket的通信方式包括( 1 ),( 2 )是最常用的套接字类型。第11题:文中( 1 )处正确的答案是( )。A.字节流套接字B.数据报套接字C.原始数据报套接字D.A、B和C

考题 客户负责建立客户到服务器的套接字连接,即客户负责呼叫。因此,服务器必须建立一个等待接收客户的套接字的Socket对象。() 此题为判断题(对,错)。

考题 我们可以方便地编写Java客户机/服务器程序,在客户机/服务器模式中,客户机一般通过套接字(Socket)使用服务器所提供的服务,Socket由两部分组成:IP地址和端口号。() 此题为判断题(对,错)。

考题 支持双向的数据流,但并不保证是可靠、有序、无重复的是()。A、流套接字B、数据报套接字C、客户端套接字D、服务器端套接字

考题 用电信息采集远程通信有三种通信模式:客户机模式、服务器模式和混合模式。江苏采用的是()A、客户机模式B、服务器模式C、混合模式

考题 下列进程通信方式中不属于一个计算机中进程之间的通信的是()A、管道B、套接字C、消息队列D、共享内存

考题 高级通信有共享内存、()、套接字和邮箱通信。

考题 套接字之间的连接过程分为服务器监听、()和连接确认。

考题 属于因特网的重要作用的是()。A、通信线路、路由器、服务器和客户机B、路由器、服务器、客户机和信息资源C、通信线路、路由器、服务器和信息资源D、通信线路、路由器、服务器、客户机、信息资源

考题 单选题当本地计算机要关闭客户机与服务器应用程序的TCP连接或监听套接字时,应调用Winsock控件的()方法。A UnloadB OpenC AcceptD Close

考题 单选题属于因特网的重要作用的是()。A 通信线路、路由器、服务器和客户机B 路由器、服务器、客户机和信息资源C 通信线路、路由器、服务器和信息资源D 通信线路、路由器、服务器、客户机、信息资源

考题 问答题如何用套接字完成一个客户机/服务器的通信?

考题 填空题高级通信有共享内存、()、套接字和邮箱通信。