socket在windows下和linux下的区别

1)头文件 
windows下winsock.h/winsock2.h 
linux下sys/socket.h    错误处理:errno.h 

2)初始化 
windows下需要用WSAStartup

WSADATA wsaData;

        err = WSAStartup(0x202,&wsaData); if ( err != 0 ) { return 0; } else if ( LOBYTE( wsaData.wVersion ) != 2 || HIBYTE( wsaData.wVersion ) != 2 ) //检测是否支持这个版本的socket { WSACleanup( ); return 0; }

对应的退出清理用WSACleanup( );
linux下不需要 

3)关闭socket 
windows下closesocket(...) 
linux下close(...) 

4)socket类型 
windows下SOCKET 
linux下int 

5)获取错误码 
windows下WSAGetLastError() 

linux下errno变量

extern int errno;
        int geterror(){return errno;}

6)设置非阻塞 
windows下ioctlsocket(server_socket,FIONBIO,&ul);     int ul = 1
linux下fcntl(server_socket,F_SETFL, O_NONBLOCK);    <fcntl.h> 


7)send函数最后一个参数 
windows下一般设置为0 
linux下必须是后几个参数用到的socket中,值最大的数(整型)加1 (另一种说法是设置为MSG_NOSIGNAL)


8)毫秒级时间获取 
windows下GetTickCount() 
linux下gettimeofday() 

 

9)编译连接

windows下ws2_32.lib
linux下

连接是使用参数:-lstdc
        运行时需要libstdc++.so.5,可在/usr/lib目录中创建一个链接。

 

10)Socket操作错误返回值

都为SOCKET_ERROR,他的值是-1

 

11)异常处理

windows下没有对send()的异常处理,最后一个参数无效,写0就可以了。

linux下

当连接断开,还发数据的时候,不仅send()的返回值会有反映,而且还会像系统发送一个异常消息,如果不作处理,系统会出BrokePipe,程序会退出。为此,send()函数的最后一个参数可以设置MSG_NOSIGNAL,禁止send()函数向系统发送异常消息。

 

12)WSA宏

 

windows下WSA相关的操作

linux下WSA相关的操作在Linux不必要,直接去掉即可

 


3、多线程 
多线程: (win)process.h --〉(linux)pthread.h 
_beginthread --> pthread_create 
_endthread --> pthread_exit

  • 2
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Windows系统下,TCP_INFO选项可以通过getsockopt函数来获取TCP socket的相关信息,如下: ```c #include <winsock2.h> #include <mswsock.h> #include <ws2tcpip.h> #include <stdio.h> int main(int argc, char* argv[]) { WSADATA wsaData; int result = WSAStartup(MAKEWORD(2, 2), &wsaData); if (result != 0) { printf("WSAStartup failed: %d\n", result); return 1; } SOCKET sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (sock == INVALID_SOCKET) { printf("Socket creation failed: %d\n", WSAGetLastError()); WSACleanup(); return 1; } /* Set up the sockaddr_in structure */ struct sockaddr_in server; server.sin_family = AF_INET; server.sin_addr.s_addr = inet_addr("127.0.0.1"); server.sin_port = htons(8080); /* Connect to the server */ result = connect(sock, (struct sockaddr *)&server, sizeof(server)); if (result == SOCKET_ERROR) { printf("Connect failed: %d\n", WSAGetLastError()); closesocket(sock); WSACleanup(); return 1; } /* Get the TCP socket info */ struct tcp_info info; int infoLength = sizeof(info); result = getsockopt(sock, IPPROTO_TCP, TCP_INFO, (char *)&info, &infoLength); if (result != 0) { printf("Getsockopt failed: %d\n", WSAGetLastError()); closesocket(sock); WSACleanup(); return 1; } printf("TCP_INFO state: %u\n", info.tcpi_state); closesocket(sock); WSACleanup(); return 0; } ``` 在Linux系统下,TCP_INFO选项可以通过getsockopt函数来获取TCP socket的相关信息,如下: ```c #include <sys/socket.h> #include <netinet/in.h> #include <netinet/tcp.h> #include <stdio.h> int main(int argc, char *argv[]) { int sock = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); if (sock == -1) { perror("Socket creation failed"); return 1; } /* Set up the sockaddr_in structure */ struct sockaddr_in server; server.sin_family = AF_INET; server.sin_addr.s_addr = inet_addr("127.0.0.1"); server.sin_port = htons(8080); /* Connect to the server */ int result = connect(sock, (struct sockaddr *)&server, sizeof(server)); if (result == -1) { perror("Connect failed"); close(sock); return 1; } /* Get the TCP socket info */ struct tcp_info info; socklen_t infoLength = sizeof(info); result = getsockopt(sock, IPPROTO_TCP, TCP_INFO, (char *)&info, &infoLength); if (result != 0) { perror("Getsockopt failed"); close(sock); return 1; } printf("TCP_INFO state: %u\n", info.tcpi_state); close(sock); return 0; } ``` 这两段代码都是获取TCP socket的状态信息,打印出状态码tcpi_state。这个状态码可以表示TCP连接的状态,如TCP_SYN_SENT、TCP_ESTABLISHED、TCP_FIN_WAIT1等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值