有没有更好的方法来反转内存中的字节数组?

xia*_*ian 11 c++ memory swap std

typedef unsigned char Byte;

...

void ReverseBytes( void *start, int size )
{
    Byte *buffer = (Byte *)(start);

    for( int i = 0; i < size / 2; i++ ) {
        std::swap( buffer[i], buffer[size - i - 1] );
    }
}
Run Code Online (Sandbox Code Playgroud)

这个方法现在做的是它在内存中反转字节.我想知道的是,有没有更好的方法来达到同样的效果?整个"尺寸/ 2"部分似乎是一件坏事,但我不确定.

编辑:我刚刚意识到我为这个问题提出的标题有多糟糕,所以我[希望]修复它.

kmk*_*lan 26

标准库具有以下std::reverse功能:

#include <algorithm>
void ReverseBytes( void *start, int size )
{
    char *istart = start, *iend = istart + size;
    std::reverse(istart, iend);
}
Run Code Online (Sandbox Code Playgroud)

  • 反向函数的描述表明,它的实现方式与提出问题的人实现它的方式完全相同,并且具有相同的复杂性。这确实不是一个更好的方法。一种更清洁的方式也许是最好的.. (2认同)

Mic*_*ner 18

不使用STL的高性能解决方案:

void reverseBytes(void *start, int size) {
    unsigned char *lo = start;
    unsigned char *hi = start + size - 1;
    unsigned char swap;
    while (lo < hi) {
        swap = *lo;
        *lo++ = *hi;
        *hi-- = swap;
    }
}
Run Code Online (Sandbox Code Playgroud)

虽然问题是3岁半,但其他人可能会寻找相同的东西.这就是为什么我仍然发布这个.

  • 机会已经实现:) (7认同)