博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
htonl、ntohl、htons、ntohs函数实现
阅读量:7097 次
发布时间:2019-06-28

本文共 1226 字,大约阅读时间需要 4 分钟。

hot3.png

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);

}

转载于:https://my.oschina.net/u/1455799/blog/209056

你可能感兴趣的文章
JavaScript高级程序设计:第一章
查看>>
基础才是重中之重~你是否真正了解TransactionScope?
查看>>
JS~模拟表单在新窗口打开,避免广告拦截
查看>>
ANSI最全介绍linux终端字体改变颜色等
查看>>
数据结构5——堆
查看>>
11Linux_sshd_Apache
查看>>
Android hdpi ldpi mdpi xhdpi xxhdpi适配详解
查看>>
Java_4.1 猜数字游戏
查看>>
Openstack的mysql数据多主galera的错误
查看>>
文件关联程序
查看>>
归并排序、堆排序与快速排序分析(2)
查看>>
CodeForces 567C Geometric Progression
查看>>
xfreerdp的用法
查看>>
DockerCon 2017最新技术解读
查看>>
旋转矩阵的算法
查看>>
贝叶斯方法的m-估计
查看>>
2015-2016-2 课程
查看>>
冒泡排序
查看>>
BZOJ2298:[HAOI2011]problem a(DP)
查看>>
网络流初步详解2
查看>>