linux字节序转换函数和地址转换函数

刚才阅读代码的时候看到了一个字节排序函数,一时想不起具体用法了。想想学习linux下的网络编程也不少时间了,这些字节排序和转换的函数还是不太清楚,容易混淆。今天索性把这方面的知识汇总一下,争取以后能够熟练的认识和运用。
字节顺序函数:
小端字节序:将低序字节存储在起始地址。(linux)
大端字节序:将高序字节存储在起始地址。(网络字节序)
举个例子:对于整数0x12345678来说,在不同的系统中存放的方式如下图:

linux字节序转换函数和地址转换函数_第1张图片

正是因为网际协议采取的是大端字节序,我们在编程的时候才需要考虑网络字节许和主机字节序之间的转换。下面是四个转换函数(在某些采用大端字节序的系统里面,这四个函数被定位空宏):

 

#include <netinet/in.h> uint16_t htons(uint16_t host16bitvalue); uint32_t htonl(uint32_t host32bitvalue); //均返回网络字节序 uint16_t ntohs(uint16_t net16bitvalue); uint32_t ntohl(uint32_t net32bitvalue); //均返回主机字节序 

 

地址转换函数:
下面介绍两组地址转换函数。首先是第一组:

 

#include <arpa/inet.h> int inet_aton(const char *strptr, struct in_addr *addrptr); //返回:1——串有效,0——串有错 char* inet_ntoa(struct in_addr inaddr); //返回一个指向ASCII字串的指针 in_addr_t inet_addr(const char *strptr); //成功返回网络字节序,错误返回INADDR_NONE 

 

接下来是第二组,这两个函数比较新,对于IPv4和IPv6都能处理。p的含义是presentation,代表ASCII字串。n的含意是numberic,代表网络地址值。

 

#include <netinet/in.h> #define INET_ADDRSTRLEN 16 #define INET6_ADDRSTRLEN 46 #include <arpa/inet.h> int inet_pton(int family, const char *strptr, void *addrptr); //返回:1——成功,输入的不是有效表达格式,-1——出错 const char* inet_ntop(int family, const void *addrptr, char *strptr, size_t len); //返回:指向结果的指针——成功,NULL——出错 

你可能感兴趣的:(编程,linux,网络,struct,null,存储)