linux socketaddr中的sin_addr前面的sin前缀是什么意思?

Error 404 (Not Found)!!1
404. That’s an error.
The requested URL /304404/ was not found on this server.
That’s all we know.问题:sockaddr_in 是干什么用的,还有sin_family成员为什么要赋值AF_INET类型,addrsin_Addrsaddr又是干什么的
问题描述:sockaddr_ addr.sin_family = AF_INET; addr.sin_addr.s_addr = inet_addr( &127.0.0.1& );//inet_addr(&&)//是干什么的 & &addr.sin_port = htons(8000); //addr.sin_port是做什么的,htons()函数是干什么的问题解答1:socket编程。 linux和windows基本一样。而且windows socket编程是从linux socket编程继承来的。你需要补充socket编程的内容。问题解答2:sockaddr_in 是一个IP地址+端口的组合,还包括了网络类型AF_INET 就是局域网,
以上介绍了“sockaddr_in 是干什么用的,还有sin_family成员为什么要赋值AF_INET类型,addrsin_Addrsaddr又是干什么的”的问题解答,希望对有需要的网友有所帮助。
本文网址链接:/wd/454539.html
上一篇: 下一篇:sockaddr 是通用的socket地址,具体到Internet socket,用下面的结构,二者可以进行类型转换
sa_family是地址家族,一般都是“AF_xxx”的形式。通常大多用的是都是AF_INET,代表TCP/IP协议族
sa_data是14字节协议地址。
此数据结构用做bind、connect、recvfrom、sendto等函数的参数,指明地址信息。但一般编程中并不直接针对此数据结构操作,而是使用另一个与sockaddr等价的数据结构
struct hostent {
char *h_ /* 主机的官方域名 */
   char **h_ /* 一个以NULL结尾的主机别名数组 */
   int h_ /* 返回的地址类型,在Internet环境下为AF-INET */
   int h_ /* 地址的字节长度 */
   char **h_addr_ /* 一个以0结尾的数组,包含该主机的所有地址*/
#define h_addr h_addr_list[0] /*在h-addr-list中的第一个地址*/
struct sockaddr {
unsigned short sa_ // address family, AF_xxx
char sa_data[14]; // 14 bytes of protocol address
sockaddr_in
通常的用法是:
sockaddr_in
socket(AF_INET,
SOCK_STREAM,
my_addr.sin_family
my_addr.sin_port
htons(MYPORT);
my_addr.sin_addr.s_addr
inet_addr("192.168.0.1");
bzero(&(my_addr.sin_zero),
bind(sockfd,
*)&my_addr,
sizeof(struct
sockaddr));
sockaddr_in
// Address family
sin_ // Port number
/* Internet address */
sin_zero[8];
/* Same size as struct sockaddr */
struct { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b;
struct { u_short s_w1,s_w2; } S_un_w;
#define s_addr
S_un.S_addr
struct in_addr就是32位IP地址
sin_family指代协议族,在socket编程中只能是AF_INET
  sin_port存储端口号(使用网络字节顺序)
  sin_addr存储IP地址,使用in_addr这个数据结构
  sin_zero是为了让sockaddr与sockaddr_in两个数据结构保持大小相同而保留的空字节。
  s_addr按照网络字节顺序存储IP地址
  sockaddr_in和sockaddr是并列的结构,指向sockaddr_in的结构体的指针也可以指向
  sockaddr的结构体,并代替它。也就是说,你可以使用sockaddr_in建立你所需要的信息,
  然后用进行类型转换就可以了bzero((char)&mysock,sizeof(mysock));//初始化
  sockaddr_
  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()是将一个点分制的IP地址(如192.168.0.1)转换为上述结构中需要的32位IP地址(0xC0A80001)。
阅读(...) 评论()1637人阅读
struct & sockaddr & { &&& & & & & & & & unsigned & short & sa_ & /* & 地址族, & AF_xxx & */ &&& & & & & & & & char & sa_data[14]; & /* & 14字节的协议地址*/ &&& & & & };&&&& 上面是通用的socket地址,具体到Internet & socket,用下面的结构,二者可以进行类型转换 &&& & & & &&& struct & sockaddr_in & { &&& & & & & & & & short & int & sin_ & /* & 地址族,AF_xxx&&在socket编程中只能是AF_INET */ &&& & & & & & & & unsigned & short & int & sin_ & /* & 端口号&&(使用网络字节顺序) */ &&& & & & & & & & struct & in_addr & sin_ & /*&& 存储IP地址&&4字节 */ &&& & & & & & & & unsigned & char & sin_zero[8]; & /*&& 总共8个字节,实际上没有什么用,只是为了和struct&&sockaddr保持一样的长度 & */ &&& & & & };&&&&&&&&&& struct & in_addr就是32位IP地址。&&&&&&&&&& struct & in_addr & {&&&&&&&&&&&&&&&&&& union {&&&&&&&&&&&&&&&&&&&&&&&&struct { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b;&&&&&&&&&&&&&&&&&&&&&&&&struct { u_short s_w1,s_w2; } S_un_w;&&&&&&&&&&&&&&&&&&&&&&& u_long S_& /*& 按照网络字节顺序存储IP地址& */&&&&&&&&&&&&&&&&} S_
&&&&&&&&&&&&&&& #define s_addr& S_un.S_addr&&&&&&& };&&&&& inet_addr()是将一个点分制的IP地址(如192.168.0.1)转换为上述结构中需要的32位IP地址(0xC0A80001)。
填值的时候使用sockaddr_in结构,而作为函数(如socket, listen, bind等)的参数传入的时候转换成sockaddr结构就行了,毕竟都是16个字符长。
通常的用法是: &&& int & &&& struct & sockaddr_in & my_ &&& sockfd & = & socket(AF_INET, & SOCK_STREAM, & 0); & /* & 做一些错误检查! & */ &&& &&& my_addr.sin_family & = & AF_INET; & /* & 主机字节序 & */ &&& my_addr.sin_port & = & htons(MYPORT); & /* & short, & 网络字节序 & */ &&& my_addr.sin_addr.s_addr & = & inet_addr("192.168.0.1"); &&& &&& bzero(&(my_addr.sin_zero), & 8); & /* & zero & the & rest & of & the & struct & */ &&& /* & 不要忘了为bind()做错误检查: & */ &&& bind(sockfd, & (struct & sockaddr & *)&my_addr, & sizeof(struct & sockaddr));
可以用C++做个不太准确的假设。&&&sockaddr是base & class&&&&&sockaddr_in & 等是derived & class&&&如此一来,bind, & connect & , & sendto & , & recvfrom等函数就可以使用base & class&&&来处理多种不同的derived & class了。&&&但是实际上,这是没有继承关系数据结构(C嘛),所以需要强制造型来转换数据类型。正因为如此,在sendto的时候需要给出len长度,因为不同的sockaddr_xx实现长度并不相同。
名词解析:
主机字节序:
不同的CPU有不同的字节序类型,这些字节序是指整数在内存中保存的顺序,这个叫做主机序。最常见的有两种&1.Little endian:低字节存高地址,高字节存低地址 2.Big endian:低字节存低地址,高字节存高地址
网络字节序:
网络字节顺序是TCP/IP中规定好的一种数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释。网络字节顺序采用big endian排序方式。
为了进行转换bsd socket提供了转换的函数,有下面四个网络与主机字节转换函数:htons ntohs htonl ntohl (s 就是short l是long h是host n是network)
htons 把unsigned short类型从主机序转换到网络序,htonl 把unsigned long类型从主机序转换到网络序,ntohs 把unsigned short类型从网络序转换到主机序,ntohl 把unsigned long类型从网络序转换到主机序。
在使用little endian的系统中 这些函数会把字节序进行转换 在使用big endian类型的系统中 这些函数会定义成空宏
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:110568次
积分:1608
积分:1608
排名:千里之外
原创:48篇
转载:18篇
评论:12条
(1)(4)(1)(10)(11)(3)(15)(2)(6)(5)(8)
(window.slotbydup = window.slotbydup || []).push({
id: '4740881',
container: s,
size: '200,200',
display: 'inlay-fix'新手园地& & & 硬件问题Linux系统管理Linux网络问题Linux环境编程Linux桌面系统国产LinuxBSD& & & BSD文档中心AIX& & & 新手入门& & & AIX文档中心& & & 资源下载& & & Power高级应用& & & IBM存储AS400Solaris& & & Solaris文档中心HP-UX& & & HP文档中心SCO UNIX& & & SCO文档中心互操作专区IRIXTru64 UNIXMac OS X门户网站运维集群和高可用服务器应用监控和防护虚拟化技术架构设计行业应用和管理服务器及硬件技术& & & 服务器资源下载云计算& & & 云计算文档中心& & & 云计算业界& & & 云计算资源下载存储备份& & & 存储文档中心& & & 存储业界& & & 存储资源下载& & & Symantec技术交流区安全技术网络技术& & & 网络技术文档中心C/C++& & & GUI编程& & & Functional编程内核源码& & & 内核问题移动开发& & & 移动开发技术资料ShellPerlJava& & & Java文档中心PHP& & & php文档中心Python& & & Python文档中心RubyCPU与编译器嵌入式开发驱动开发Web开发VoIP开发技术MySQL& & & MySQL文档中心SybaseOraclePostgreSQLDB2Informix数据仓库与数据挖掘NoSQL技术IT业界新闻与评论IT职业生涯& & & 猎头招聘IT图书与评论& & & CU技术图书大系& & & Linux书友会二手交易下载共享Linux文档专区IT培训与认证& & & 培训交流& & & 认证培训清茶斋投资理财运动地带快乐数码摄影& & & 摄影器材& & & 摄影比赛专区IT爱车族旅游天下站务交流版主会议室博客SNS站务交流区CU活动专区& & & Power活动专区& & & 拍卖交流区频道交流区
丰衣足食, 积分 720, 距离下一级还需 280 积分
论坛徽章:0
#include &sys/socket.h&
#include &netinet/in.h&
#include &arpa/inet.h&
#include &stdio.h&
int main(void)
{
& && &&&const char *address = &192.168.10.66&;
& && &&&struct sockaddr_
& && &&&inet_aton(address, &addr.sin_addr);
& && &&&printf(&IP Addr : %u\n&, addr.sin_addr);
复制代码
编译的时候总是提示类型不对,把%u换成%d也不行,不知道这里应该用什么格式字符?
&&nbsp|&&nbsp&&nbsp|&&nbsp&&nbsp|&&nbsp&&nbsp|&&nbsp
白手起家, 积分 30, 距离下一级还需 170 积分
论坛徽章:0
%s itoa(addr,sin_addr)
丰衣足食, 积分 720, 距离下一级还需 280 积分
论坛徽章:0
原帖由 mergn 于
17:07 发表
%s itoa(addr,sin_addr)
没有这个函数,我想把点分十进制的IP地址用网络字节序的32位ip地址方式显示。
小富即安, 积分 2104, 距离下一级还需 2896 积分
论坛徽章:0
addr.sin_addr.s_addr
丰衣足食, 积分 720, 距离下一级还需 280 积分
论坛徽章:0
#include &sys/socket.h&
#include &netinet/in.h&
#include &arpa/inet.h&
#include &stdio.h&
int main(void)
{
& && &&&const char *address = &192.168.10.66&;
& && &&&struct sockaddr_
& && &&&inet_aton(address, &addr.sin_addr);
& && &&&printf(&IP Addr : %d\n&, addr.sin_addr.s_addr);
& && &&&return 0;
}
复制代码
怪我自己粗心,应该是addr.sin_addr.s_addr,而不是addr.sin_addr。}

我要回帖

更多关于 socketaddr in 头文件 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信