您好,登錄后才能下訂單哦!
本篇內容主要講解“C語言sockaddr和sockaddr_in的區別什么是”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“C語言sockaddr和sockaddr_in的區別什么是”吧!
sockaddr在頭文件#include <sys/socket.h>中定義,sockaddr的缺陷是:sa_data把目標地址和端口信息混在一起了,如下:
struct sockaddr { sa_family_t sin_family;//地址族 char sa_data[14]; //14字節,包含套接字中的目標地址和端口信息 };
sockaddr_in在頭文件#include<netinet/in.h>或#include <arpa/inet.h>中定義,該結構體解決了sockaddr的缺陷,把port和addr 分開儲存在兩個變量中,如下:
sin_port和sin_addr都必須是網絡字節序(NBO),一般可視化的數字都是主機字節序(HBO)。
二者長度一樣,都是16個字節,即占用的內存大小是一致的,因此可以互相轉化。二者是并列結構,指向sockaddr_in結構的指針也可以指向sockaddr。
sockaddr常用于bind、connect、recvfrom、sendto等函數的參數,指明地址信息,是一種通用的套接字地址。
sockaddr_in 是internet環境下套接字的地址形式。所以在網絡編程中我們會對sockaddr_in結構體進行操作,使用sockaddr_in來建立所需的信息,最后使用類型轉化就可以了。一般先把sockaddr_in變量賦值后,強制類型轉換后傳入用sockaddr做參數的函數:sockaddr_in用于socket定義和賦值;sockaddr用于函數參數。
例子如下:
#include <stdio.h> #include <stdlib.h> #include <sys/socket.h> #include <netinet/in.h> int main(int argc,char **argv) { int sockfd; struct sockaddr_in mysock; sockfd = socket(AF_INET,SOCK_STREAM,0); //獲得fd bzero(&mysock,sizeof(mysock)); //初始化結構體 mysock.sin_family = AF_INET; //設置地址家族 mysock.sin_port = htons(800); //設置端口 mysock.sin_addr.s_addr = inet_addr("192.168.1.0"); //設置地址 bind(sockfd,(struct sockaddr *)&mysock,sizeof(struct sockaddr); /* bind的時候進行轉化 */ ... ... return 0; }
題外話,兩個函數 htons() 和 inet_addr()。
htons()作用是將端口號由主機字節序轉換為網絡字節序的整數值。(host to net)
inet_addr()作用是將一個IP字符串轉化為一個網絡字節序的整數值,用于sockaddr_in.sin_addr.s_addr。
inet_ntoa()作用是將一個sin_addr結構體輸出成IP字符串(network to ascii)。比如:
printf("%s",inet_ntoa(mysock.sin_addr));
htonl()作用和htons()一樣,不過它針對的是32位的(long),而htons()針對的是兩個字節,16位的(short)。
與htonl()和htons()作用相反的兩個函數是:ntohl()和ntohs()。
到此,相信大家對“C語言sockaddr和sockaddr_in的區別什么是”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。