htonll 在linux上的实现

64位字节序转换函数htonll是windows平台上的函数,Linux平台下未提供此函数。

下面这2个函数提供了很好的功能,但是存在一些不足,没有进行本机的字节序判断,如果本机也是大端,那么,应该做的是不进行任何转换,直接输出,因此这2个函数此时会出错。

htonll和ntohll函数的实现_David.li的博客-CSDN博客_ntohll

uint64_t htonll(uint64_t val)
{
    return (((uint64_t) htonl(val)) << 32) + htonl(val >> 32);
}
 
uint64_t ntohll(uint64_t val)
{
    return (((uint64_t) ntohl(val)) << 32) + ntohl(val >> 32);
}

因此需要进行判断


#ifndef WIN32
uint64_t htonll(uint64_t val)
{
	if (1 == htonl(1))
		return val;
	return (((uint64_t)htonl(val)) << 32) + htonl(val >> 32);
}

uint64_t ntohll(uint64_t val)
{
	if (1 == htonl(1))
		return val;
	return (((uint64_t)ntohl(val)) << 32) + ntohl(val >> 32);
}
#endif

这样就可以安全地使用ntohll

linux - 64 bit ntohl() in C++? - Stack Overflow

还有一种办法是,在Linux平台下使用

 头文件:#include <endian.h>,/usr/include/endian.h,实际实现在/usr/include/bits/byteswap.h,定义了所有转换的宏函数:

        (无符号)64字节主机转网络:htobe64(uint64_t data)

        (无符号)64字节网络转主机:be64toh(uint64_t data)

关于字节序_FSak47的博客-CSDN博客_htobe64

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

路边闲人2

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值