copy

 

#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实现的更多相关文章

  1. 【网络编程一】主机字节序与网络字节序以及ip地址转换函数

    在计算机设计之初,对内存中数据的处理也有不同的方式,(低位数据存储在低位地址处或者高位数据存储在低位地址处),然而,在通信的过程中(ISO/OSI模型和TCP/IP四层模型中),数据被一步步封装(然后 ...

  2. Apache服务(基于IP地址,主机名,端口号)

    安装Apache服务程序 需要注意apache服务程序的软件包名称叫做httpd,因此直接执行yum install apache则是错误的. [root@liuxuanke-hbza ~]# yum ...

  3. 套接字编程相关函数(1:套接字地址结构、字节序转换、IP地址转换)

    1. 套接字地址结构 1.1 IPv4套接字地址结构 IPv4套接字地址结构通常也称为“网际套接字地址结构”,它以sockaddr_in命名,定义在<netinet/in.h>头文件中.下 ...

  4. IP地址转换函数

    只适用于IPV4 inet_addr函数将用点分十进制字符串表示的IPv4地址转化为用网络字节序整数表示的IPv4地址. 失败时返回INADDR_NONE. inet_aton函数完成和inet_ad ...

  5. Linux C++ - IP地址转换函数

    1. 函数用途:数字网络序本地序转换 适用类型:IP地址uint32_t类型.端口号uint16_t类型 #include<netinet/in.h> extern uint32_t nt ...

  6. 四、IP地址转换

    IP地址与端口 TCP/IP(传输控制协议/网际协议)不是一个协议,而是一组协议的总称,包括IP.TCP.UDP.ICMP.ARP等.它规范了网络上的所有通信设备,尤其是一个主机与另一个主机之间的数据 ...

  7. python整数与IP地址转换

    python整数与IP地址转换 [转] 我们有时会将一个整数与IP地址进行互换,用python代码实现很简单将一个整数如2000000,变为一个IP地址的方式 >>> import ...

  8. python整数与IP地址转换 [转]

    我们有时会将一个整数与IP地址进行互换,用python代码实现很简单将一个整数如2000000,变为一个IP地址的方式 >>> import socket >>> ...

  9. ip地址转换

    通常,我们用点分十进制字符串表示ipv4地址(192.168.1.1),用十六进制字符串表示ipv6地址(fe80::20c:29ff:fee9:4bcc). ipv4转换函数 #include &l ...

  10. [转]字符型IP地址转换成数字IP的SQL函数

    使用SQL函数可以实现许多的功能,下面为您介绍的是字符型IP地址转换成数字IP的SQL函数示例,供您参考,希望对您学习SQL函数能够有所帮助.      /**//*--调用示例       sele ...

随机推荐

  1. Decode Ways——动态规划

    A message containing letters from A-Z is being encoded to numbers using the following mapping: 'A' - ...

  2. matlab实用命令

    实用命令 打点测时 在需要测量的开始部分标记: tic 在需要测量的结束部分标记: toc 记录程序从tic到toc运行所花费的时间 Image 翻转 fliplr(x) //左右翻转 flipud( ...

  3. ffmepg的基本使用

    基本使用命令 ffmpeg -i input.mp4 output.avi //视频格式转换 ffmepg -i input.mp4 -r fps image%3d.jpg //视频转成图片 //fp ...

  4. 我XXXX!!!够了!!!从github拉到dockerhub,再用daocloud加速下载

    史上比较曲折的救国方式了... 先在git hub上申请帐号,导入dockerfile. 然后在docker hub上关联git hub帐号作自动构建. 再用daocloud作加速,将docker i ...

  5. string char * const char *之间的互相转换

    string  ->   const char * 用str的c_str()方法或者data()方法均可,这个两个方法返回值为cong char * string str = "hel ...

  6. SPOJ - SUBST1 D - New Distinct Substrings

    D - New Distinct Substrings 题目大意:求一个字符串中不同子串的个数. 裸的后缀数组 #include<bits/stdc++.h> #define LL lon ...

  7. 使用for循环打印9×9乘法表

    请使用for循环,倒序打印9×9乘法表. 打印结果如下图所示: 使用for循环打印9×9乘法表 #include <stdio.h> int main() { int i, j, resu ...

  8. POJ 3259 Wormholes【最短路/SPFA判断负环模板】

    农夫约翰在探索他的许多农场,发现了一些惊人的虫洞.虫洞是很奇特的,因为它是一个单向通道,可让你进入虫洞的前达到目的地!他的N(1≤N≤500)个农场被编号为1..N,之间有M(1≤M≤2500)条路径 ...

  9. 34、Flask实战第34天:修改邮箱

    修改邮箱页面布局 新建cms/cms_resetemail.html {% extends 'cms/cms_base.html' %} {% block title %}修改邮箱-CMS管理系统{% ...

  10. 最近升级mysql5.7出现下面问题,ORDER BY clause is not in GROUP BY..this is incompatible with sql_mode=only_full_group_by

    执行sql: SELECT * FROM `user_link` WHERE `group_id` IN ('78', '79') GROUP BY `link_id` 报错: SQLSTATE[42 ...