windows下的C语言socket编程没有相关socket的头文件怎么办?

windows下的C语言socket编程没有相关socket的头文件怎么办?,第1张

//服务端代码\x0d\x0a#include\x0d\x0a#include\x0d\x0a#pragma comment(lib,"ws2_32.lib")//这句关键\x0d\x0avoid main(){\x0d\x0aWORD wV\x0d\x0aWSADATA ws\x0d\x0aint er\x0d\x0awV=MAKEWORD(1,1)\x0d\x0aer=WSAStartup(wV,&ws)\x0d\x0aif(er!=0){\x0d\x0areturn\x0d\x0a\x0d\x0a}\x0d\x0aif(LOBYTE(ws.wVersion)!=1||HIBYTE(ws.wVersion)!=1){\x0d\x0aWSACleanup()\x0d\x0areturn\x0d\x0a}\x0d\x0aSOCKET sockSrv=socket(AF_INET,SOCK_STREAM,0)\x0d\x0aSOCKADDR_IN addrSrv\x0d\x0aaddrSrv.sin_addr.S_un.S_addr=htonl(INADDR_ANY)\x0d\x0aaddrSrv.sin_family=AF_INET\x0d\x0aaddrSrv.sin_port=htons(6000)\x0d\x0a\x0d\x0abind(sockSrv,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR))\x0d\x0a\x0d\x0alisten(sockSrv,5)\x0d\x0a\x0d\x0aSOCKADDR_IN addrClient\x0d\x0aint len=sizeof(SOCKADDR)\x0d\x0awhile(1)\x0d\x0a{\x0d\x0aSOCKET sockConn=accept(sockSrv,(SOCKADDR*)&addrClient,&len)\x0d\x0a\x0d\x0achar sendBuf[100]\x0d\x0asprintf(sendBuf,"welcome %s to wozhe",inet_ntoa(addrClient.sin_addr))\x0d\x0asend(sockConn,sendBuf,strlen(sendBuf)+1,0)\x0d\x0achar recvBuf[100]\x0d\x0arecv(sockConn,recvBuf,100,0)\x0d\x0aprintf("%s\n",recvBuf)\x0d\x0aclosesocket(sockConn)\x0d\x0a}\x0d\x0a}\x0d\x0a\x0d\x0a//客户端\x0d\x0a#include\x0d\x0a#include\x0d\x0a#pragma comment(lib,"ws2_32.lib")\x0d\x0avoid main(){\x0d\x0aWORD wV\x0d\x0aWSADATA ws\x0d\x0aint er\x0d\x0awV=MAKEWORD(1,1)\x0d\x0aer=WSAStartup(wV,&ws)\x0d\x0aif(er!=0){\x0d\x0areturn\x0d\x0a\x0d\x0a}\x0d\x0aif(LOBYTE(ws.wVersion)!=1||HIBYTE(ws.wVersion)!=1){\x0d\x0aWSACleanup()\x0d\x0areturn\x0d\x0a}\x0d\x0a\x0d\x0aSOCKET sockC=socket(AF_INET,SOCK_STREAM,0)\x0d\x0aSOCKADDR_IN addrS\x0d\x0aaddrS.sin_addr.S_un.S_addr=inet_addr("127.0.0.1")\x0d\x0aaddrS.sin_family=AF_INET\x0d\x0aaddrS.sin_port=htons(6000)\x0d\x0aconnect(sockC,(SOCKADDR*)&addrS,sizeof(SOCKADDR))\x0d\x0achar recvB[100]\x0d\x0arecv(sockC,recvB,100,0)\x0d\x0aprintf("%s\n",recvB)\x0d\x0asend(sockC,"this is list",strlen("this is list")+1,0)\x0d\x0aclosesocket(sockC)\x0d\x0aWSACleanup()\x0d\x0a}

1. 头文件

windows下winsock.h或winsock2.h

linux下netinet/in.h(大部分都在这儿),unistd.h(close函数在这儿),sys/socket.h(在in.h里已经包含了,可以省了)

2. 初始化

windows下需要用WSAStartup启动Ws2_32.lib,并且要用#pragma comment(lib,"Ws2_32")来告知编译器链接该lib。

linux下不需要

3. 关闭socket

windows下closesocket(...)

linux下close(...)

4. 类型

windows下SOCKET

linux下int

5. 获取错误码

windows下getlasterror()/WSAGetLastError()

linux下,未能成功执行的socket *** 作会返回-1;如果包含了errno.h,就会设置errno变量

6. 设置非阻塞

windows下ioctlsocket()

linux下fcntl(),需要头文件fcntl.h

7. send函数最后一个参数

windows下一般设置为0

linux下最好设置为MSG_NOSIGNAL,如果不设置,在发送出错后有可能会导致程序退出

8. 毫秒级时间获取

windows下GetTickCount()

linux下gettimeofday()

socket编程在windows和linux下的区别有以下几点:1)头文件windows下winsock.h或winsock2.hlinux下netinet/in.h(大部分都在这儿),unistd.h(close函数在这儿),sys/socket.h(在in.h里已经包含了,可以省了)2)初始化windows下需要用WSAStartup启动Ws2_32.lib,并且要用#pragmacomment(lib,"Ws2_32")来告知编译器链接该lib。linux下不需要3)关闭socketwindows下closesocket()linux下close()4)类型windows下SOCKETlinux下int(我喜欢用long,这样保证是4byte,因为-1我总喜欢写成0xFFFF)5)获取错误码windows下getlasterror()/WSAGetLastError()linux下,未能成功执行的socket *** 作会返回-1;如果包含了errno.h,就会设置errno变量6)设置非阻塞windows下ioctlsocket()linux下fcntl(),需要头文件fcntl.h7)send函数最后一个参数windows下一般设置为0linux下最好设置为MSG_NOSIGNAL,如果不设置,在发送出错后有可能会导致程序退出8)毫秒级时间获取windows下GetTickCount()linux下gettimeofday()9)多线程windows下包含process.h,使用_beginthread和_endthreadlinux下包含pthread.h,使用pthread_create和pthread_exit10)用IP定义一个地址(sockaddr_in的结构的区别)windows下addr_var.sin_addr.S_un.S_addrlinux下addr_var.sin_addr.s_addr而且Winsock里最后那个32bit的S_addr也有几个以联合(Union)的形式与它共享内存空间的成员变量(便于以其他方式赋值),而Linux的Socket没有这个联合,就是一个32bit的s_addr。遇到那种得到了是4个char的IP的形式(比如127一个,0一个,0一个和1一个共四个char),WinSock可以直接用4个S_b来赋值到S_addr里,而在Linux下,可以用边向左移位(一下8bit,共四下)边相加的方法赋值。11)异常处理linux下当连接断开,还发数据的时候,不仅send()的返回值会有反映,而且还会像系统发送一个异常消息,如果不作处理,系统会出BrokePipe,程序会退出。为此,send()函数的最后一个参数可以设MSG_NOSIGNAL,禁止send()函数向系统发送异常消息。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/8009840.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-12
下一篇 2023-04-12

发表评论

登录后才能评论

评论列表(0条)

保存