inet_ntop4实现的功能,就是将网络字节序地址转化成 ip地址字符串
网络字节序地址:就是一个char[4] 类型,将ip地址的4个元素依次存放在数组
ip地址字符串: “127.0.0.1”
#include<string.h>
#include<stdio.h>
#include<unistd.h>
extern const char *inet_ntop4 (const void *__restrict __cp,
char *__restrict __buf, socklen_t __len)
{
__uint8_t tempCp[4];
memcpy(&tempCp, __cp, 4);
char tempStr[16];
sprintf(tempStr, "%u.%u.%u.%u", tempCp[0], tempCp[1], tempCp[2], tempCp[3]);
memcpy(__buf, tempStr, __len);
return (__buf);
}
int main()
{
char ip[] = {127,0,0,1};
char buff[30];
inet_ntop4(ip, buff, 30);
printf("%s\n", buff);
return 0;
}
我们一般都是将 ip地址字符串 转成 网络字节序地址
比如我们写基础socket代码时:
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <netdb.h>
#include <stdio.h>
#include <string.h>
int main()
{
int fd = socket(AF_INET, SOCK_STREAM, 0);
struct sockaddr_in addr;
addr.sin_family = AF_INET;
addr.sin_port = htons(8001);
inet_pton(AF_INET, "127.0.0.1", &addr.sin_addr); // 这里就是将ip字符串转化成 网络字节序地址
return 0;
}
当我们查看 sin_addr,它的结构是:
typedef uint32_t in_addr_t;
struct in_addr
{
in_addr_t s_addr;
};
这里用了一个 32位的int来存储 char[4] ,不得不说设计的很巧妙。
我需用用到ip地址时,用 memcpy 把__uint32_t的变量写到指定的类型变量就可以使用。
多思考,多实践,多看源码才能找出答案。有时候网络上的答案未必靠谱。