1.通常,人们习惯于使用可读性好的字符串来表示IP的地址,但是,在实际的使用过程中,需要使用的IP地址应该为无符号的整数(在计算机中存储时是对应的二进制,只有二进制计算机才能识别,即0、1)。已经封装好的函数,可以帮助我们快速的完成IP地址和网络字节序之间的转换。
2.代码:
/*利用函数实现IP地址(字符串)和网络字节序的转换(整数)*/
#include <stdio.h>
#include <arpa/inet.h>
int main()
{
    //创建一个点分是十进制的IP地址字符串
    char buf[] = "192.168.1.1";
    unsigned int num = 0;
    //将点分十进制的IP字符串转换成网络字节序的整数
    inet_pton(AF_INET,buf,&num);
    unsigned char *p = (unsigned char *)#
    printf("%d %d %d %d \n",*p,*(p+1),*(p+2),*(p+3));
    //将网络字节序的IP整数转换成点分十进制的IP字符串
    char ip[16] = "";
    const char *str = inet_ntop(AF_INET,&num,ip,16);    //str与ip的值是相同的
    printf("str : %s\n",str);
    printf("ip : %s\n",ip);
    
    return 0;
} 
3.运行结果:

4.总结:用字符串表示IP地址具有可读性好的优点,但是,计算机只能识别二进制(0、1对应着高低电平), 因此,需要将IP地址字符串转换成网络字节序整数。通过,封装好的函数可方便的完成二者之间的转换。



















