关于 linux 中sockaddr_in

本文介绍了在Windows和Linux环境下socket编程中的关键数据结构sockaddr及sockaddr_in,详细解释了这些结构体成员变量的作用,包括地址家族、端口号、IP地址等,并通过一个服务端和客户端的示例展示了如何使用这些结构进行socket编程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在windows/linux下有下面结构:
sockaddr结构
struct sockaddr {
unsigned short sa_family; /* address family, AF_xxx */
char sa_data[14]; /* 14 bytes of protocol address */
};
sa_family是地址家族,一般都是“AF_xxx”的形式。通常大多用的是都是 AF_INET,代表TCP/IP协议族。
sa_data是14字节 协议地址
数据结构用做bind、connect、recvfrom、sendto等函数的参数,指明地址信息。但一般编程中并不直接针对此 数据结构操作,而是使用另一个与sockaddr等价的数据结构
sockaddr_in(在netinet/in.h中定义):
struct sockaddr_in {
short sin_family; /* Address family */
unsigned short sin_port; /* Port number */
struct  in_addr sin_addr; /* Internet address */
unsigned char sin_zero[8]; /* Same size as struct sockaddr */
};
在linux下:
in_addr结构
typedef struct  in_addr{
unsigned long s_addr;
};
在windows下:
typedef struct  in_addr{
union{
struct{unsigned char s_b1,s_b2,s_b3,s_b4;} S_un_b;
struct{unsigned short s_w1,s_w2;} S_un_w;
unsigned long S_addr;
} S_un;
} IN_ADDR;

编辑本段参数说明

sin_family指代协议族,在socket编程中只能是AF_INET
sin_port存储 端口号(使用网络 字节顺序),在linux下,端口号的范围0~65535,同时0~1024范围的端口号已经被系统使用或保留。
s in_addr存储IP地址,使用in_addr这个 数据结构
sin_zero是为了让sockaddr与sockaddr_in两个 数据结构保持大小相同而保留的空字节。
s_addr按照网络字节顺序存储IP地址
sockaddr_in和sockaddr是并列的结构,指向sockaddr_in的 结构体指针也可以指向
sockaddr的 结构体,并代替它。也就是说,你可以使用sockaddr_in建立你所需要的信息,
然后用bzero函数初始化就可以了bzero((char*)&mysock,sizeof(mysock));//初始化
sockaddr_in mysock;
bzero((char*)&mysock,sizeof(mysock));
mysock.sa_family=AF_INET;
mysock.sin_port=htons(1234);//1234是 端口号
mysock.s in_addr.s_addr=inet_addr("192.168.0.1");
相关函数:inet_addr, inet_aton, inet_ntoa, htonl, htons, MAKEWORD, WSASocket, WSAHtons……

编辑本段经典案例

服务端:
int main()
{
//创建socket
int sockfd=socket(PF_LOCAL, SOCK_DGRAM, 0);
if(sockfd==-1)
perror("创建socket失败"),exit(-1);
//准备通信地址
struct sockaddr_un addr;
addr.sun_family = PF_UNIX;
strcpy(addr.sun_path,"a.sock"); 
//绑定
int res = bind(sockfd, 
(struct sockaddr*)&addr, sizeof(addr));
if(res==-1)perror("绑定失败"),exit(-1);
printf("绑定成功\n");
//通信(用读写文件方式)
char buf[100] = {};
read(sockfd, buf, sizeof(buf)); 
printf("收到信息:%s\n", buf);
//关闭socket
close(sockfd); 
}
客户端:
int main()
{
int sockfd=socket(PF_LOCAL, SOCK_DGRAM, 0);
if(sockfd==-1)
perror("创建socket失败"),exit(-1);
struct sockaddr_un addr;
addr.sun_family = PF_UNIX;
strcpy(addr.sun_path,"a.sock"); 
//连接
int res = connect(sockfd, 
(struct sockaddr*)&addr, sizeof(addr));
if(res==-1)perror("失败"),exit(-1);
printf("成功\n");
write(sockfd, "Hello, Socket!", 14);
close(sockfd); 
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值