函数inet_addr和inet_aton

本文详细介绍了IP地址在不同字节顺序间的转换方法,包括inet_addr、inet_aton等函数的应用及区别,强调了网络字节顺序的重要性。
 

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;
}
`inet_aton` `inet_ntoa` 是用于在 IP 地址的点分十进制字符串表示形式 32 位二进制整数之间进行转换的标准函数,常用于网络编程中处理 IPv4 地址。这两个函数属于 POSIX 标准库中的 `<arpa/inet.h>` 头文件(在 Linux/Unix 系统中)。 ### `inet_aton` 该函数将 IPv4 地址从字符串表示形式(如 `"192.168.1.1"`)转换为网络字节序的 32 位二进制整数(即 `in_addr_t` 类型)。其原型如下: ```c int inet_aton(const char *cp, struct in_addr *inp); ``` - `cp`:指向一个以点分十进制格式表示的 IPv4 地址字符串。 - `inp`:指向一个 `struct in_addr` 结构体的指针,用于存储转换后的二进制地址。 返回值: - 成功时返回 1; - 输入无效则返回 0。 示例代码: ```c #include <stdio.h> #include <arpa/inet.h> int main() { struct in_addr ip; int success = inet_aton("192.168.1.1", &ip); if (success) { printf("Binary representation: %u\n", ip.s_addr); } else { printf("Invalid address.\n"); } return 0; } ``` ### `inet_ntoa` 该函数的作用与 `inet_aton` 相反,它将网络字节序的 32 位 IPv4 地址转换为点分十进制字符串形式。其原型如下: ```c char *inet_ntoa(struct in_addr in); ``` - `in`:包含网络字节序的 IPv4 地址的 `struct in_addr` 结构体。 返回值是一个静态分配的字符串,表示转换后的 IP 地址[^1]。 示例代码: ```c #include <stdio.h> #include <arpa/inet.h> int main() { struct in_addr ip; inet_aton("192.168.1.1", &ip); char *ip_str = inet_ntoa(ip); printf("IP Address: %s\n", ip_str); return 0; } ``` ### 注意事项 - `inet_ntoa` 返回的是一个静态缓冲区的指针,因此在多线程环境中或多次调用时需要注意数据覆盖问题。 - 这两个函数仅支持 IPv4 地址。对于 IPv6 地址,应使用 `inet_pton` `inet_ntop` 函数来替代。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值