使用指针浏览内存中的二进制记录的纠结列表

我有以下.bin文件

1f ac 00 78 00 3f 00 c3 00 83....

我应该使用指针算法来完成它.我应该抓住第一个字节,它会告诉我将要处理多少“单词”,然后每两个字节就会告诉我我应该开始读取的偏移量.我的问题是我得到第一个字节没有任何问题,但现在我所要做的就是增加我的指针,使其指向ac,将其转换为uint16_t,打印出该值,执行一些程序,现在我希望它指向78.这是我到目前为止所写的内容:

 Pre: Buffer points to a region of memory formatted as specified.
      Log points to an opened text file. 
 Post: The target of Buffer has been parsed and report written as specified
uint8_t doStuff(uint8_t *Buffer, FILE *Log) // given function parameters
{
    int wordsToProcess = *(Buffer); // get that first byte
    uint16_t offset = 0;
    bool firstTime = true;

    for  (int i = 0; i < wordsToProcess; i++)
    {
        if (firstTime)
        {
            Buffer++; // I've tried Buffer += 1;
            offset = *((uint16_t*)Buffer); // casting turns into little endian.
                                           // I want 00 ac but I'm not getting that

            fprintf(Log, "Looking for %0X words, starting at %0X\n",
                    wordsToProcess, offset);

            firstTime = false;
        }
        else
        {
            Buffer += 2;
            offset = *((uint16_t*)Buffer);
        }
    }
}

我甚至删除了除hexdump之外的几乎所有内容,除了前两个字节,我仍然得到66.我也试过使指针具有与Buffer相同的地址并从那里开始因为我认为可能正在使用Buffer导致我的问题,但同样的交易.谁能帮我弄清楚我做错了什么?

最佳答案 我不知道可能是什么问题,因为数据可能不是你所期望的那样.但是你的代码有一些问题恕我直言.

这就是它更易读,更容易理解,更容易编写(更容易编写,更少的错误).

uint8_t
doStuff(uint8_t *buffer, FILE *log)
{
    int wordCount = *buffer++;
    uint16_t *pointer = (uint16_t *) buffer;
    uint16_t offset = *pointer++;
    pointer += offset;
    for  (int i = 0; i < wordCount; i++)
        fprintf(log, "0x%04X ", *pointer++);
    return 0 // I don't know what you want to return;
}

请注意,如果数据没有预期的结构,则此代码将导致未定义的行为.

点赞