做过网络通信的人都用过 inet_addr()函数,这个函数的功能就是讲字符串转化成点分十进制,
也就是带有特殊格式的atoi()函数。
但用过inet_ntoa函数的人应该挺少,我自己写了一个类似于inet_ntoa的函数。
我做的是目前主流的ip4的转化,
主要的接口函数如下,传入一个无符号整型32字节的数字,返回一个ip字符串。
char* inet_ntoa(uint32_t ip)
{
char* str = (char*)malloc(16);
memset(str, 0, 16);
uint32_t num = 0;
int i = 0;
for(i = 0; i < 4; i++)
{
num = (ip & (255 << ((3 - i) * 8))) >> ((3-i)*8);
fill_str(num, str+i*4);
if( i == 3) break;
str[i*4+4 - 1] = '.';
}
return str;
}
inet_ntoa函数中关于ip的左移右移我觉得有必要解释一下,因为字符串ip是由
点隔开的,单个数字最大的是255,例如 255.255.255.255,其点分十进制是由4个字节
构成,从左至右由高字节往低字节递减,因而有
for i = 0 to 3
最左面
i = 0;
tmp = ip &(0xff << (3 - i)*8)为最高的一个字节代表的数值大小
通过右移 tmp >> (3 - i)*8则得到上面得到数值对应的最高位的数。
同理,其他三位也可得出。
void fill_str(uint32_t num, char* str)
{
str[0] = num / 100 + '0';
str[1] = num % 100 /10 + '0';
str[2] = num % 10 + '0';
}
例如
输入
2130706433
输出 127.0.0.1
输入 2021182159
输出 12.13.14.15