发布网友 发布时间:2022-04-20 08:03
共2个回答
热心网友 时间:2022-05-23 16:59
函数说明:socket()用来建立一个新的socket, 也就是向系统注册, 通知系统建立一通信端口. 参数domain 指定使用何种的地址类型, 完整的定义在/usr/include/bits/socket.h 内, 底下是常见的协议:
PF_UNIX/PF_LOCAL/AF_UNIX/AF_LOCAL UNIX 进程通信协议
PF_INET?AF_INET Ipv4 网络协议
PF_INET6/AF_INET6 Ipv6 网络协议
PF_IPX/AF_IPX IPX-Novell 协议
PF_NETLINK/AF_NETLINK 核心用户接口装置
PF_X25/AF_X25 ITU-T X. 25/ISO-8208 协议
PF_AX25/AF_AX25 业余无线AX. 25 协议
PF_ATMPVC/AF_ATMPVC 存取原始 ATM PVCs
PF_APPLETALK/AF_APPLETALK appletalk (DDP)协议
PF_PACKET/AF_PACKET 初级封包接口
参数 type 有下列几种数值:
1、SOCK_STREAM 提供双向连续且可信赖的数据流, 即TCP. 支持 OOB 机制, 在所有数据传送前必须使用connect()来建立连线状态.
2、SOCK_DGRAM 使用不连续不可信赖的数据包连接
3、SOCK_SEQPACKET 提供连续可信赖的数据包连接
4、SOCK_RAW 提供原始网络协议存取
5、SOCK_RDM 提供可信赖的数据包连接
6、SOCK_PACKET 提供和网络驱动程序直接通信. protocol 用来指定socket 所使用的传输协议编号, 通常此参考不用管它, 设为0 即可.
返回值:成功则返回socket 处理代码, 失败返回-1.
错误代码:
1、EPROTONOSUPPORT 参数domain 指定的类型不支持参数type 或protocol 指定的协议
2、ENFILE 核心内存不足, 无法建立新的socket 结构
3、EMFILE 进程文件表溢出, 无法再建立新的socket
4、EACCESS 权限不足, 无法建立type 或protocol 指定的协议
5、ENOBUFS/ENOMEM 内存不足
6、EINVAL 参数domain/type/protocol 不合法
热心网友 时间:2022-05-23 17:00
以下是简单socket通信的例子
客户端代码:
// client.c : 定义控制台应用程序的入口点。
//
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <conio.h>
#include <winsock2.h>
#pragma comment(lib,"ws2_32.lib")
int main()
{
WSADATA wsadata;
WORD socketversion = MAKEWORD(2,2);
if(::WSAStartup(socketversion,&wsadata) != 0)
{
printf("启动windows socket失败!\n");
}
SOCKET clientsocket;
if((clientsocket = ::socket(AF_INET,SOCK_STREAM,0)) == INVALID_SOCKET)
{
printf("创建套接字失败!\n");
::closesocket(clientsocket);
exit(0);
}
sockaddr_in client;
client.sin_family = AF_INET;
client.sin_port = htons(5051);
client.sin_addr.S_un.S_addr = htonl(INADDR_ANY);
if(::bind(clientsocket,(sockaddr *)&client,sizeof(client)) == SOCKET_ERROR)
{
printf("绑定地址失败\n");
::closesocket(clientsocket);
exit(0);
}
sockaddr_in server;
server.sin_family = AF_INET;
server.sin_port = htons(5050);
server.sin_addr.S_un.S_addr = inet_addr("172.19.36.8");
if(::connect(clientsocket,(sockaddr *)&server,sizeof(server)) == SOCKET_ERROR)
{
printf("服务器连接失败\n");
::closesocket(clientsocket);
exit(0);
}
printf("服务器连接成功");
while(1)
{
char buf[1024];
::memset(buf,0,sizeof(buf));
gets(buf);
char *p_c;
int count;
int numchr;
p_c = buf;
//p_c = (LPSTR)(LPCTSTR)m_sendstr;
count = sizeof(buf);
numchr=0;
do
{
numchr = send(clientsocket,p_c,count,0);
if(numchr == SOCKET_ERROR)
{
printf("发送错误");
}
else
{
p_c+=numchr;
count-=numchr;
}
}while(count>0);
}
getch();
return 0;
}