为了账号安全,请及时绑定邮箱和手机立即绑定

在C中将大端点转换为小端点[不使用提供的函数]

在C中将大端点转换为小端点[不使用提供的函数]

C
德玛西亚99 2019-07-10 14:51:31
在C中将大端点转换为小端点[不使用提供的函数]在C中,我需要编写一个函数来将大端点转换为小端点。我不能使用任何库函数。
查看完整描述

3 回答

?
慕哥9229398

TA贡献1877条经验 获得超6个赞

假设您需要的是一个简单的字节交换,请尝试如下

无符号16位转换:

swapped = (num>>8) | (num<<8);

无符号32位转换:

swapped = ((num>>24)&0xff) | // move byte 3 to byte 0
                    ((num<<8)&0xff0000) | // move byte 1 to byte 2
                    ((num>>8)&0xff00) | // move byte 2 to byte 1
                    ((num<<24)&0xff000000); // byte 0 to byte 3

这将字节顺序从位置1234转换为4321。如果你的输入是0xdeadbeef,则32位Endian交换可能具有0xefbeadde.

上面的代码应该用宏或者至少用常量来清除,而不是神奇的数字,但是希望它能起到作用。

编辑:正如另一个答案所指出的,有平台、操作系统和指令集的特定选项,它们比上面的要快得多。在Linux内核中,有一些宏(例如cpu_to_be 32),它们很好地处理了endianness。但这些替代物是特定于它们的环境的。在实践中,最好使用多种可用的方法来处理Endianness问题。


查看完整回答
反对 回复 2019-07-10
?
慕尼黑8549860

TA贡献1818条经验 获得超11个赞

包括:

#include <byteswap.h>

您可以获得与机器相关的字节交换函数的优化版本。然后,您可以轻松地使用以下功能:

__bswap_32 (uint32_t input)

__bswap_16 (uint16_t input)


查看完整回答
反对 回复 2019-07-10
?
守着一只汪

TA贡献1872条经验 获得超3个赞

#include <stdint.h>//! Byte swap unsigned shortuint16_t swap_uint16( uint16_t val ) {
    return (val << 8) | (val >> 8 );}//! Byte swap shortint16_t swap_int16( int16_t val ) {
    return (val << 8) | ((val >> 8) & 0xFF);}//! Byte swap unsigned intuint32_t swap_uint32( uint32_t val ){
    val = ((val << 8) & 0xFF00FF00 ) | ((val >> 8) & 0xFF00FF ); 
    return (val << 16) | (val >> 16);}//! Byte swap intint32_t swap_int32( int32_t val ){
    val = ((val << 8) & 0xFF00FF00) | ((val >> 8) & 0xFF00FF ); 
    return (val << 16) | ((val >> 16) & 0xFFFF);}

更新增加了64位字节交换

int64_t swap_int64( int64_t val ){
    val = ((val << 8) & 0xFF00FF00FF00FF00ULL ) | ((val >> 8) & 0x00FF00FF00FF00FFULL );
    val = ((val << 16) & 0xFFFF0000FFFF0000ULL ) | ((val >> 16) & 0x0000FFFF0000FFFFULL );
    return (val << 32) | ((val >> 32) & 0xFFFFFFFFULL);}uint64_t swap_uint64( uint64_t val ){
    val = ((val << 8) & 0xFF00FF00FF00FF00ULL ) | ((val >> 8) & 0x00FF00FF00FF00FFULL );
    val = ((val << 16) & 0xFFFF0000FFFF0000ULL ) | ((val >> 16) & 0x0000FFFF0000FFFFULL );
    return (val << 32) | (val >> 32);}


查看完整回答
反对 回复 2019-07-10
  • 3 回答
  • 0 关注
  • 699 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信