sockaddr_in , sockaddr , in_addr区别

基本结构

      在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范围的端口号已经被系统使用或保留。

  sin_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.sin_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、付费专栏及课程。

余额充值