IP地址转换、主机大小端、htonl、ntohl实现
http://blog.csdn.net/zww0815/article/details/7592940
- #include <IOSTREAM>
- //#include <WINSOCK.H>
- using namespace std;
- typedef unsigned short int uint16;
- typedef unsigned long int uint32;
- // 短整型大小端互换
- #define BigLittleSwap16(A) ((((uint16)(A) & 0xff00) >> 8) | \
- (((uint16)(A) & 0x00ff) << 8))
- // 长整型大小端互换
- #define BigLittleSwap32(A) ((((uint32)(A) & 0xff000000) >> 24) | \
- (((uint32)(A) & 0x00ff0000) >> 8) | \
- (((uint32)(A) & 0x0000ff00) << 8) | \
- (((uint32)(A) & 0x000000ff) << 24))
- // 本机大端返回1,小端返回0
- int checkCPUendian()
- {
- union{
- unsigned long int i;
- unsigned char s[4];
- }c;
- c.i = 0x12345678;
- return (0x12 == c.s[0]);
- }
- // 模拟htonl函数,本机字节序转网络字节序
- unsigned long int t_htonl(unsigned long int h)
- {
- // 若本机为大端,与网络字节序同,直接返回
- // 若本机为小端,转换成大端再返回
- return checkCPUendian() ? h : BigLittleSwap32(h);
- }
- // 模拟ntohl函数,网络字节序转本机字节序
- unsigned long int t_ntohl(unsigned long int n)
- {
- // 若本机为大端,与网络字节序同,直接返回
- // 若本机为小端,网络数据转换成小端再返回
- return checkCPUendian() ? n : BigLittleSwap32(n);
- }
- // 模拟htons函数,本机字节序转网络字节序
- unsigned short int t_htons(unsigned short int h)
- {
- // 若本机为大端,与网络字节序同,直接返回
- // 若本机为小端,转换成大端再返回
- return checkCPUendian() ? h : BigLittleSwap16(h);
- }
- // 模拟ntohs函数,网络字节序转本机字节序
- unsigned short int t_ntohs(unsigned short int n)
- {
- // 若本机为大端,与网络字节序同,直接返回
- // 若本机为小端,网络数据转换成小端再返回
- return checkCPUendian() ? n : BigLittleSwap16(n);
- }
- //8个二进制(2个十六进制)数转换成十进制数,不含a-f。即00-99的转换
- int transfer_0(int x)
- {
- int y;//结果
- int temp;//临时值
- y=x%10;//个位数
- temp=(x%100-y)/10;//十位数
- y+=temp*16;
- return y;
- }
- //32个二进制(4个十六进制)数转换成十进制数,不含a-f。即0000-9999的转换
- void transfer_1(unsigned int x)
- {
- //从右向左
- int temp1=x%100;
- int y1=transfer_0(temp1);
- int temp2=(x%10000-temp1)/100;
- int y2=transfer_0(temp2);
- int temp3=(x%1000000-temp1-temp2*100)/10000;
- int y3=transfer_0(temp3);
- int temp4=(x%100000000-temp1-temp2*100-temp3*10000)/1000000;
- int y4=transfer_0(temp4);
- printf("结果是:%d.%d.%d.%d\n",y4,y3,y2,y1);
- }
- //将16进制数数转化成10进制数,一位的0-F。
- int transfer_0(char x)
- {
- int y=0;//返回值
- if (x>='0' && x<='9')//0-9的数字
- {
- y=x-'0';
- return y;
- }
- if (x>='a' && x<='f')//a-f的字母
- {
- y=x-'a'+10;
- return y;
- }
- if (x>='A' && x<='F')//A-F的字母
- {
- y=x-'A'+10;
- return y;
- }
- printf("参数错误!");
- exit(1);
- }
- //将16进制数数转化成10进制数,八位的00000000-FFFFFFFF。
- void transfer_3(char x[],int n)//长度为8
- {
- //从左往右
- int y0=transfer_0(x[0]);
- int y1=transfer_0(x[1]);
- int y2=transfer_0(x[2]);
- int y3=transfer_0(x[3]);
- int y4=transfer_0(x[4]);
- int y5=transfer_0(x[5]);
- int y6=transfer_0(x[6]);
- int y7=transfer_0(x[7]);
- printf("结果是:%d.%d.%d.%d\n",y0*16+y1,y2*16+y3,y4*16+y5,y6*16+y7);
- }
- //将16进制数数转化成10进制数,八位的00000000-FFFFFFFF。
- void transfer_4(char x[])
- {
- //从左往右
- int y1=transfer_0(x[0])*16+transfer_0(x[1]);
- int y2=transfer_0(x[2])*16+transfer_0(x[3]);
- int y3=transfer_0(x[4])*16+transfer_0(x[5]);
- int y4=transfer_0(x[6])*16+transfer_0(x[7]);
- printf("结果是:%d.%d.%d.%d\n",y1,y2,y3,y4);
- }
- int main()
- {
- int ret;
- ret = checkCPUendian();
- if (ret == 1)
- {
- printf("返回1,本机为大端\n");
- }
- else
- {
- printf("返回0,本机为小端\n");
- }
- return 0;
- }
-------------------------------
htonl(),htons(),ntohl(),ntons()--大小端模式转换函数
不同机器内部对变量的字节存储顺序不同,有的采用大端模式(big-endian),有的采用小端模式(little-endian)。
大端模式是指高字节数据存放在低地址处,低字节数据放在高地址处。
小端模式是指低字节数据存放在低地址处,高字节数据放在高地址处。
在网络上传输数据时,由于数据传输的两端可能对应不同的硬件平台,采用的存储字节顺序也可能不一致,因此 TCP/IP 协议规定了在网络上必须采用网络字节顺序(也就是大端模式) 。
通过对大小端的存储原理分析可发现,对于 char 型数据,由于其只占一个字节,所以不存在这个问题,这也是一般情况下把数据缓冲区定义成 char 类型 的原因之一。对于 IP 地址、端口号等非 char 型数据,必须在数据发送到网络上之前将其转换成大端模式,在接收到数据之后再将其转换成符合接收端主机的存储模式。
Linux 系统为大小端模式的转换提供了 4 个函数,输入 man byteorder 命令可得函数原型:
#include <arpa/inet.h>
uint32_t htonl(uint32_t hostlong);
uint16_t htons(uint16_t hostshort);
uint32_t ntohl(uint32_t netlong);
uint16_t ntohs(uint16_t netshort);
htonl 表示 host to network long ,用于将主机 unsigned int 型数据转换成网络字节顺序;
htons 表示 host to network short ,用于将主机 unsigned short 型数据转换成网络字节顺序;
ntohl、ntohs 的功能分别与 htonl、htons 相反。
转载于:https://www.cnblogs.com/kungfupanda/archive/2013/05/03/3056505.html
IP地址转换、主机大小端、htonl、ntohl实现相关推荐
- 网络字节顺序和主机字节顺序的转换(htons ntohs htonl ntohl)
from https://blog.csdn.net/baidu_33621692/article/details/53213002 网络字节顺序和主机字节顺序的转换(htons ntohs hto ...
- 1.socket编程:socket编程,网络字节序,函数介绍,IP地址转换函数,sockaddr数据结构,网络套接字函数,socket相关函数,TCP server和client
1 Socket编程 socket这个词可以表示很多概念: 在TCP/IP协议中,"IP地址+TCP或UDP端口号"唯一标识网络通讯中的一个进程,"IP 地址+端 ...
- 【Linux网络编程学习】预备知识(网络字节序、IP地址转换函数、sockaddr数据结构)
此为牛客Linux C++课程和黑马Linux系统编程笔记. 1. 网络字节序 我们已经知道,内存中的多字节数据相对于内存地址有大端和小端之分. 磁盘文件中的多字节数据相对于文件中的偏移地址也有大端小 ...
- linux的基础知识——网络字节序转化,ip地址转换函数,sockaddr数据结构
1.网络字节序 TCP/IP协议规定,网络数据流采用大端字节序,即低地址高字节.为了使网络程序具有可移植性,使得同样的C代码在大端和小端计算机上编译后都能正常运行,可以调用以下库函数做网络字节序和主机 ...
- python整数与IP地址转换
我们有时会将一个整数与IP地址进行互换,用python代码实现很简单 将一个整数如2000000,变为一个IP地址的方式 >>> import socket >>> ...
- 第22节 NAT——实现公私有IP地址转换
NAT 1 NAT概述 1.1 IP地址概述 1.2NAT概述 2 NAT分类 2.1 静态NAT 2.2 动态NAT 2.3 PAT 2.4 静态PAT 3 NAT命令 3.1 定义内外网接口 3. ...
- python整数与IP地址转换 [转]
原文地址为: python整数与IP地址转换 [转] 我们有时会将一个整数与IP地址进行互换,用python代码实现很简单 将一个整数如2000000,变为一个IP地址的方式 >>> ...
- 防火墙关键技术(包过滤、应用代理、网络ip地址转换)
目录 数据包过滤 包过滤优点 包过滤缺点 应用代理 应用代理优点 应用代理缺点 网络IP地址转换(NAT) 数据包过滤 网络上的数据都是以包为单位进行传输的,每一个数据包中都会包含一些特定的信息,如数 ...
- NAT技术配置(内外网IP地址转换)
NAT技术配置(内外网IP地址转换) 一. 什么是NAT? NAT是将IP数据报文头中的IP地址转换成另一个IP地址的过程,主要用于实现内部地址(私有IP地址)访问外部地址(公有IP地址)的功 ...
- 利用函数进行ip地址转换
inet_addr.inet_ntoa.inet_pton.inet_ntop用法 inet_addr(): inet_ntoa(): inet_pton(): inet_ntop(): 运行实例 1 ...
最新文章
- 树莓派 ubuntu 安装Python+OpenCV
- 构建良好的敏捷团队氛围
- hana::detail::variadic::foldr1用法的测试程序
- YUV422/420 format
- J2CL –迟到总比不到好
- tensor判断是否相等_PyTorch的Tensor(中)
- kind富文本编辑器_在VueJs中集成UEditor 富文本编辑器
- python文件批量重命名以数字~n的方式重命名_利用Python对文件进行批量重命名
- lambda方法引用总结——烧脑吃透
- Mycat监控_监控平台安装Mycat-web_作为配置中心注册发现用---MyCat分布式数据库集群架构工作笔记0037
- python数字图像处理(13):基本形态学滤波
- HTML(超文本标记语言)的内容和理解
- 远程服务器桌面配置iis6,windows 2003服务器安装 IIS6.0和IIS自带FTP服务器图文教程...
- C++ malloc头文件
- 中标麒麟linux系统安装打印机_国产操作系统中标麒麟系统安装教程
- SEM 与 SEO 之间的区别与联系
- 对视图有时为什么使用select top 100 percent * 而不使用 select * 呢?
- 计算机考试照片是一寸,怎么用电脑拍照片_怎么用电脑将照片修成一寸大小
- 游戏开发之Unity2021智能导航地图烘焙
- 程序员常见英文缩写及其意义