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

本文介绍了网络编程中常见的字节顺序转换函数及其用法,包括小端和大端字节序的概念,并详细解释了htons、htonl、ntohs、ntohl等函数的应用场景。同时,还介绍了地址转换函数inet_aton、inet_ntoa、inet_addr、inet_pton、inet_ntop的作用。
刚才阅读代码的时候看到了一个字节排序函数,一时想不起具体用法了。想想学习linux下的网络编程也不少时间了,这些字节排序和转换的函数还是不太清楚,容易混淆。今天索性把这方面的知识汇总一下,争取以后能够熟练的认识和运用。
字节顺序函数:
小端字节序:将低序字节存储在起始地址。(linux)
大端字节序:将高序字节存储在起始地址。(网络字节序)
举个例子:对于整数0x12345678来说,在不同的系统中存放的方式如下图:
  
正是因为网际协议采取的是大端字节序,我们在编程的时候才需要考虑网络字节许和主机字节序之间的转换。下面是四个转换函数(在某些采用大端字节序的系统里面,这四个函数被定位空宏):

#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——出错                

转载于:https://www.cnblogs.com/cesc711/archive/2009/10/12/1581985.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值