C++中正确使用PRId64 (转载)
转自:http://blog.csdn.net/win_lin/article/details/7912693
例子参考高性能流媒体服务器SRS:https://github.com/winlinvip/simple-rtmp-server
SRS中广泛使用PRId64实现32和64位系统通用。
c++使用PRID64,需要两步:
- 包含头文件:<inttypes.h>
- 定义宏:__STDC_FORMAT_MACROS,可以通过编译时加-D__STDC_FORMAT_MACROS,或者在包含文件之前定义这个宏。
int64_t用来表示64位整数,在32位系统中是long long int,在64位系统中是long int,所以打印int64_t的格式化方法是:
printf("%ld", value); // 64bit OS printf("%lld", value); // 32bit OS
当然有跨平台的方法:
#include <inttypes.h> printf("%" PRId64 "\n", value); // 相当于64位的: printf("%" "ld" "\n", value); // 或32位的: printf("%" "lld" "\n", value);
其中,printf("abc" "def" “ghi")这样写多个字符串是没有问题的。
但是,死活都编译不过,错误是:error: expected ‘)’ before ‘PRId64’
找了一下这个宏的定义,/usr/include/inttypes.h:
/* The ISO C99 standard specifies that these macros must only be defined if explicitly requested. */ #if !defined __cplusplus || defined __STDC_FORMAT_MACROS # if __WORDSIZE == 64 # define __PRI64_PREFIX "l" # define __PRIPTR_PREFIX "l" # else # define __PRI64_PREFIX "ll" # define __PRIPTR_PREFIX # endif /* Macros for printing format specifiers. */ /* Decimal notation. */ # define PRId8 "d" # define PRId16 "d" # define PRId32 "d" # define PRId64 __PRI64_PREFIX "d"
原来这个是定义给c用的,C++要用它,就要定义一个__STDC_FORMAT_MACROS宏显示打开它。
/* test_int64.cpp g++ -D__STDC_FORMAT_MACROS -o test_int64 -g -O0 test_int64.cpp */ #include <stdio.h> #include <inttypes.h> int main(int argc, char** argv){ int64_t value = 0xFFFFFFFFFFFF; printf("int64_t=%"PRId64", sizeof(int64_t)=%d\n", value, sizeof(int64_t)); }
编译并执行:
g++ -D__STDC_FORMAT_MACROS -o test_int64 -g -O0 test_int64.cpp
./test_int64
int64_t=281474976710655, sizeof(int64_t)=8
对于C++新标准-std=c++0x,还可以使用更好的方式:
/* test_int64_1.cpp g++ -o test_int64_1 -g -O0 test_int64_1.cpp */ #include <stdio.h> #include <cinttypes> using namespace std; int main(int argc, char** argv){ int64_t value = 0xFFFFFFFFFFFF; printf("int64_t=%"PRId64", sizeof(int64_t)=%d\n", value, sizeof(int64_t)); }
不用定义那个宏了,编译和执行:
g++ -o test_int64_1 -g -O0 test_int64_1.cpp -std=c++0x
./test_int64_1
int64_t=281474976710655, sizeof(int64_t)=8
当然得指定一个新的参数:-std=c++0x,否则会报错“#error This file requires compiler and library support for the upcoming ISO C++ standard, C++0x. This support is currently experimental, and must be enabled with the -std=c++0x or -std=gnu++0x compiler options.”
若能使用较新的g++编译,可以使用后者,否则可以用前者直接定义宏。