函数inet_addr和inet_ntoa,本机字节顺序与网络字节顺序的转函数的总结

本文详细解释了网络编程中IP地址的转换原理,包括如何将数字+句点形式的IP地址转换为unsigned long类型的数值,并讨论了不同函数之间的区别和用法。同时介绍了网络字节顺序和主机字节顺序的概念,以及如何进行转换。

inet_addr  : 将"数字+句点"的格式的IP地址转换到unsigned long中,返回值已经是按照网络字节顺序了
相反inet_ntoa :把类型为struct in_addr的数据转化为"数字+句点"的形式的字符串
typedef u_int32_t in_addr_t;
struct in_addr
{
       in_addr_t s_addr;
};
本机字节顺序与网络字节顺序的转换:
#include <arpa/inet.h>
htons  ------"host to network short"
htonl   -------"host to network long"
ntohs  -------"network to host short"
ntohl   -------"network to host long"
*注意:在你的数据放到网络上的时候,确信它是网络字节顺序
网络字节顺序(大端字节)和x86机器字节顺序(小端字节)
eg:0X3132  在x86上显示21  在网络传输中为12
inet_addr返回的整数形式是网络字节序,而inet_network返回的整数形式是主机字节序。他俩都有一个小缺陷,
那就是当IP是255.255.255.255时,这两个函数会认为这是个无效的IP地址,这是历史遗留问题,其实在目前大部
分的路由器上,这个255.255.255.255的IP都是有效的。
inet_aton函数和上面这俩个函数的区别就是在于他认为255.255.255.255是有效的,他不会冤枉这个看似特殊的IP地址。对了,inet_aton函数返回的是网络字节序的IP地址。
综上所述,应该使用inet_aton和inet_ntoa这一对函数。
资料:

#include <sys/socket.h>
#include 
<netinet/in.h>
#include 
<arpa/inet.h>

typedef uint32_t in_addr_t;

int inet_aton(const char *cp, struct in_addr *inp);
in_addr_t inet_addr(
const char *cp);
in_addr_t inet_network(
const char *cp);
char *inet_ntoa(struct in_addr in);
struct in_addr inet_makeaddr(int net, int host);
in_addr_t inet_lnaof(
struct in_addr in);
in_addr_t inet_netof(
struct in_addr in);


 

// Internet address.
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_addr; 
/* port in network byte order */
        } S_un;
#define s_addr  S_un.S_addr
};
// Socket address, internet style.
struct sockaddr_in {        // struct sockaddr的一种特殊形式
        short            sin_family;    /* address family: AF_INET */
        u_short        sin_port;        
/* port in network byte order */
        
struct in_addr sin_addr;        /* port in network byte order */
        
char            sin_zero[8];    /* 8 byte pad */
};
// Structure used by kernel to store most addresses.
struct sockaddr {
        u_short sa_family; 
/* address family */
        
char    sa_data[14]; /* up to 14 bytes of direct address */
};

struct in_addr {
    unsigned 
long int s_addr;
}


 



<think>好的,用户问的是inet_addr获得的地址是网络字节序还是本机字节序。首先,我需要回忆一下inet_addr函数的作用返回值。记得这个函数是用来将IPv4地址从字符串换为二进制形式的。 然后,我应该确认网络字节序本机字节序的区别。网络字节序通常是大端模式,而本机字节序可能根据系统架构不同,比如x86一般是小端。因此,函数返回的应该是网络字节序的值,因为网络协议中使用的是大端模式,这样不同机器之间传输数据时不会出错。 接下来,我需要验证这一点是否正确。查资料或文档的话,inet_addr的返回值确实是32位的网络字节序的二进制数值。例如,字符串“192.168.1.1”会被换成对应的二进制形式,而存储为大端模式。 另外,用户可能在使用这个函数时,是否需要考虑字节序换?比如,在将结果存入结构体如sockaddr_in的时候,sin_addr的s_addr字段已经是网络字节序,所以不需要额外换。所以用户如果直接使用inet_addr的结果赋值给s_addr,是正确的做法。 用户可能的深层需求是处理网络编程中的地址换问题,担心字节序导致的错误。这时候回答需要明确说明返回值的字节序,并指出常见的应用场景,比如直接赋值给结构体成员的情况,这样用户就能正确使用该函数。 还要注意区分inet_atoninet_addr的区别,虽然功能类似,但inet_aton更推荐使用,因为它处理IPv4地址更安全,但返回值的字节序应该是一样的。不过用户的问题是关于inet_addr的,所以重点放在这个函数上。 总结回答的结构:首先明确回答是网络字节序,然后解释原因,可能给出例子说明如何使用,比如赋值给sockaddr_in结构体时的正确性,最后提醒用户不需要再进行字节序换。然后生成相关问题,比如inet_aton的比较,如何换,其他函数的区别等。</think>`inet_addr` 函数返回的地址是 **网络字节序**(大端模式)。该函数将 IPv4 地址字符串(如 `"192.168.0.1"`)换为 32 位二进制整数,且结果直接以网络字节序存储,无需额外调用 `htonl` 进行换。 例如: ```c struct sockaddr_in addr; addr.sin_addr.s_addr = inet_addr("192.168.0.1"); // 直接赋值,无需 htonl ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值