如何从uint32_t打印十六进制?

时间:2017-03-26 12:44:19

标签: c++ c printf unsigned uint32-t

我一直在处理的代码要求我以十六进制打印一个uint32_t类型的变量,填充为0,最小长度为8.到目前为止我用来执行此操作的代码是:< / p>

printf("%08lx\n",read_word(address));

其中read_word返回类型uint32_t。我使用jx,llx等格式无济于事,是否有正确的格式可以使用?

修改

我发现问题在于我正在经历的事情。函数read_word从uint32_t向量返回一个值。这似乎是导致输出hex的问题。这是一个通过引用/值问题传递,修复是什么?

read_word函数:

uint32_t memory::read_word (uint32_t address) {
  if(address>(maxWord)){
        return 0;
    }

    return mem[address];

}

内存减速:

std::vector<uint32_t> mem=decltype(mem)(1024,0);

2 个答案:

答案 0 :(得分:6)

要在C ++中执行此操作,您需要滥用填充和宽度操纵器:

#include <iostream>
#include <iomanip>
#include <cstdint>

int main()
{
    uint32_t myInt = 123456;
    std::cout << std::setfill('0') << std::setw(8) << std::hex << myInt << '\n';
}

<强>输出

0001e240

对于C来说,它会变得更加迟钝。您使用inttypes.h

#include <stdio.h>
#include <stdint.h>
#include <inttypes.h>


int main()
{
    uint32_t myInt = 123456;
    printf("%08" PRIx32 "\n", myInt);
    return 0;
}

<强>输出

0001e240

请注意,在C中,inttypes.h的常量与语言字符串连接功能一起使用,以形成所需的格式说明符。您只提供零填充和最小长度作为前导码。

答案 1 :(得分:0)

%jx +类型转换

我认为这是正确的:

#include <stdio.h>
#include <stdint.h>

int main(void) {
    uint32_t i = 0x123456;
    printf("%08jx\n", (uintmax_t)i);
    return 0;
}

编译并运行:

gcc -Wall -Wextra -pedantic -std=c99 main.c
./a.out

输出:

00123456

让我知道您是否可以生成失败的测试用例。

在Ubuntu 16.04,GCC 6.4.0中进行了测试。