IP地址转换、主机大小端、htonl、ntohl实现
#include <IOSTREAM> //#include <WINSOCK.H> using std;
- typedef uint16;
- unsigned uint32;
- // 短整型大小端互换 #define BigLittleSwap16(A) ((((uint16)(A) & 0xff00) >> 8) | \ // 长整型大小端互换 #define BigLittleSwap32(A) ((((uint32)(A) & 0xff000000) >> 24) | \ // 本机大端返回1,小端返回0 int {
- unsigned i;
- s[4];
- }c;
- (0x12 == c.s[0]);
- }
- // 模拟htonl函数,本机字节序转网络字节序 t_htonl(unsigned h)
- {
- checkCPUendian() ? h : BigLittleSwap32(h);
- }
- // 模拟ntohl函数,网络字节序转本机字节序 t_ntohl(unsigned n)
- {
- checkCPUendian() ? n : BigLittleSwap32(n);
- }
- // 模拟htons函数,本机字节序转网络字节序 t_htons(unsigned h)
- {
- checkCPUendian() ? h : BigLittleSwap16(h);
- }
- // 模拟ntohs函数,网络字节序转本机字节序 t_ntohs(unsigned n)
- {
- checkCPUendian() ? n : BigLittleSwap16(n);
- }
- //8个二进制(2个十六进制)数转换成十进制数,不含a-f。即00-99的转换 int x)
- {
- y;
- temp;
- y+=temp*16;
- y;
- }
- //32个二进制(4个十六进制)数转换成十进制数,不含a-f。即0000-9999的转换 void x)
- {
- temp1=x%100;
- y1=transfer_0(temp1);
- temp2=(x%10000-temp1)/100;
- y2=transfer_0(temp2);
- temp3=(x%1000000-temp1-temp2*100)/10000;
- y3=transfer_0(temp3);
- temp4=(x%100000000-temp1-temp2*100-temp3*10000)/1000000;
- y4=transfer_0(temp4);
- ,y4,y3,y2,y1);
- //将16进制数数转化成10进制数,一位的0-F。 int x)
- y=0;
- (x>= && x<=)
- {
- ;
- y;
- (x>= && x<=)
- +10;
- y;
- }
- (x>= && x<=)
- {
- +10;
- y;
- );
- //将16进制数数转化成10进制数,八位的00000000-FFFFFFFF。 void x[], n)
- y0=transfer_0(x[0]);
- y1=transfer_0(x[1]);
- y2=transfer_0(x[2]);
- y3=transfer_0(x[3]);
- y4=transfer_0(x[4]);
- y5=transfer_0(x[5]);
- y6=transfer_0(x[6]);
- y7=transfer_0(x[7]);
- ,y0*16+y1,y2*16+y3,y4*16+y5,y6*16+y7);
- //将16进制数数转化成10进制数,八位的00000000-FFFFFFFF。 void x[])
- {
- y1=transfer_0(x[0])*16+transfer_0(x[1]);
- y2=transfer_0(x[2])*16+transfer_0(x[3]);
- y3=transfer_0(x[4])*16+transfer_0(x[5]);
- y4=transfer_0(x[6])*16+transfer_0(x[7]);
- ,y1,y2,y3,y4);
- }
- int ret;
- ret = checkCPUendian();
- (ret == 1)
- );
- );
- 0;
- }
IP地址转换、主机大小端、htonl、ntohl实现的更多相关文章
- 【网络编程一】主机字节序与网络字节序以及ip地址转换函数
在计算机设计之初,对内存中数据的处理也有不同的方式,(低位数据存储在低位地址处或者高位数据存储在低位地址处),然而,在通信的过程中(ISO/OSI模型和TCP/IP四层模型中),数据被一步步封装(然后 ...
- Apache服务(基于IP地址,主机名,端口号)
安装Apache服务程序 需要注意apache服务程序的软件包名称叫做httpd,因此直接执行yum install apache则是错误的. [root@liuxuanke-hbza ~]# yum ...
- 套接字编程相关函数(1:套接字地址结构、字节序转换、IP地址转换)
1. 套接字地址结构 1.1 IPv4套接字地址结构 IPv4套接字地址结构通常也称为“网际套接字地址结构”,它以sockaddr_in命名,定义在<netinet/in.h>头文件中.下 ...
- IP地址转换函数
只适用于IPV4 inet_addr函数将用点分十进制字符串表示的IPv4地址转化为用网络字节序整数表示的IPv4地址. 失败时返回INADDR_NONE. inet_aton函数完成和inet_ad ...
- Linux C++ - IP地址转换函数
1. 函数用途:数字网络序本地序转换 适用类型:IP地址uint32_t类型.端口号uint16_t类型 #include<netinet/in.h> extern uint32_t nt ...
- 四、IP地址转换
IP地址与端口 TCP/IP(传输控制协议/网际协议)不是一个协议,而是一组协议的总称,包括IP.TCP.UDP.ICMP.ARP等.它规范了网络上的所有通信设备,尤其是一个主机与另一个主机之间的数据 ...
- python整数与IP地址转换
python整数与IP地址转换 [转] 我们有时会将一个整数与IP地址进行互换,用python代码实现很简单将一个整数如2000000,变为一个IP地址的方式 >>> import ...
- python整数与IP地址转换 [转]
我们有时会将一个整数与IP地址进行互换,用python代码实现很简单将一个整数如2000000,变为一个IP地址的方式 >>> import socket >>> ...
- ip地址转换
通常,我们用点分十进制字符串表示ipv4地址(192.168.1.1),用十六进制字符串表示ipv6地址(fe80::20c:29ff:fee9:4bcc). ipv4转换函数 #include &l ...
- [转]字符型IP地址转换成数字IP的SQL函数
使用SQL函数可以实现许多的功能,下面为您介绍的是字符型IP地址转换成数字IP的SQL函数示例,供您参考,希望对您学习SQL函数能够有所帮助. /**//*--调用示例 sele ...
随机推荐
- IA32系统级架构总览(二)
系统级架构由寄存器.数据结构.指令组成,这些设计对基本的系统级别的操作提供了支持,比如:内存管理.终端与异常处理.任务管理.多进程控制等. 我们先来看一看寄存器与数据结构的总汇图:现在你可能看不懂,不 ...
- Python基础系列----环境的搭建及简单输入、输出
1.Python 以下信 ...
- centos7 samba安装
http://www.cnblogs.com/muscleape/p/6385583.html 1 安装yum install samba 2 添加用户xxx smbpasswd -a xxx 3 s ...
- 【面试题】2018年最全Java面试通关秘籍汇总集!
[面试题]2018年最全Java面试通关秘籍汇总集!(转载于互联网) 前几天在交流群里有些小伙伴问面试相关的试题,当时给出了一些问题,苦于打字太累就没写下去了,但觉得这是一个很不负责任的表现,于是 ...
- Unable to find a qt build, to solve this problem specify a qt build
可能路径设置不对,比如大小写错误导致找不到qmake编译器,点击VS工具栏的QT菜单,选择options,指定qt Build所在的路径(qt安装路径),然后点击ok. 这是修改过默认安装路径的
- ajaxReturn 之前dump调试,导致$.ajax不能正常运行
ajaxReturn 之前dump调试,导致$.ajax不能正常运行 以后调试的时候,注意下这个情况
- Git的入门级玩法
作为一个还没有实际开发经验的程序员,对于版本控制多少有些陌生,我通常的做法就是项目名后面加数字标记版本,然后备注一个文档说明更新.据个人了解svn用的比较多,我也学习了一点,无非是本地下载一个服务器端 ...
- 洛谷——P1190 接水问题
P1190 接水问题 题目描述 学校里有一个水房,水房里一共装有 m 个龙头可供同学们打开水,每个龙头每秒钟的供水量相等,均为 1. 现在有 n 名同学准备接水,他们的初始接水顺序已经确定.将这些同学 ...
- 【数据结构】 最小生成树(四)——利用kruskal算法搞定例题×3+变形+一道大水题
在这一专辑(最小生成树)中的上一期讲到了prim算法,但是prim算法比较难懂,为了避免看不懂,就先用kruskal算法写题吧,下面将会将三道例题,加一道变形,以及一道大水题,水到不用高级数据结构,建 ...
- 【DFS】【贪心】Codeforces Round #411 (Div. 1) C. Ice cream coloring
对那个树进行dfs,在动态维护那个当前的冰激凌集合的时候,显然某种冰激凌仅会进出集合各一次(因为在树上形成连通块). 于是显然可以对当前的冰激凌集合贪心染色.暴力去维护即可.具体实现看代码.map不必 ...