C/C++ 中正确使用PRId32 PRId64

本文详细解析了librdkafka中使用PRId32进行整数打印的格式化方法,解释了其在不同操作系统和编译环境下的应用,以及如何在C++中正确使用此类格式化字符串。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在看librdkafka的时候看到了一个没见过的写法 %“PRId32” :

fprintf(stderr,"%% Message delivered (%zd bytes, "
                        "partition %"PRId32")\n",
                        rkmessage->len, rkmessage->partition);

所在头文件:

#include <inttypes.h> 

int64_t用来表示64位整数,在32位系统中是long long int,在64位系统中是long int,所以打印int64_t的格式化方法是:

printf("%ld", value); // 64bit OS
printf("%lld", value); // 32bit OS

注意:
因为 C++ 转译立即后随字符串字面量的字符为用户定义字面量,诸如 printf("%“PRId64”\n",n); 的 C 代码在 C++ 中非法,并在 PRId64 前要求空格。即为printf("%" PRId64 “\n”,n);

C99 标准建议 C++ 实现不应定义上述极限、常量或格式化宏,除非在包含相对的 C 头文件( stdint.h 或 inttypes.h )前(分别)定义宏 __STDC_LIMIT_MACROS 、 __STDC_CONSTANT_MACROS 或 __STDC_FORMAT_MACROS 。此建议未被采纳,并在 C11 中被移除。然而,某些实现(例如 glibc 2.17 )尝试应用此规则,而可能需要定义 __STDC 宏; C++ 编译器可以通过在某些环境自动定义它们来做变通。

定义宏在编译的时候:

-D__STDC_FORMAT_MACROS
#include <cstdio>
#include <cinttypes>
 
int main()
{
    std::printf("%zu\n", sizeof(std::int64_t));
    std::printf("%s\n", PRId64);
    std::printf("%+" PRId64 "\n", INT64_MIN);
    std::printf("%+" PRId64 "\n", INT64_MAX);
 
    std::int64_t n = 7;
    std::printf("%+" PRId64 "\n", n);
}

输出结果:

8
lld
-9223372036854775808
+9223372036854775807
+7

参考:
https://zh.cppreference.com/w/cpp/types/integer

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值