gcc那些事儿
内置宏
编译器会预定义许多宏,尤其在交叉编译时,不同的工具链编译器会定义不同的宏。例如:
- aarch64
- __ARM_ARCH_7A
- __ARM_ARCH_8A
如果使用armv7的工具链,那么只有__ARM_ARCH_7A
会被定义,而如果使用armv8的工具链,那么只有__ARM_ARCH_8A
会被定义。但以上两个编译器都会定义__aarch64__
.
How to Check Macros Predefined by Compiler
1 | aarch64-linux-gnu-gcc -march=armv8-a -E -dM - < /dev/null |
-E
是gcc
的一个common option
, 指示编译器只做预处理-d<letters>
是gcc
的一个common option
, 打开由字母指定的compiler pass的dump-dM
打印预处理阶段所有的宏#define
, 包括预定义宏。-dD
功能和-dM
类似,但它不包含预定义宏,而且它同时输出#define
和预处理结果。-dN
功能和-dD
类似,但只输出宏名,不展开宏。-dI
除了预处理结果外,还输出#include
.-dU
功能和-dD
类似,但只输出那些被展开的宏或在预处理中被#if
,#ifndef
测试过的宏。
__builtin_offsetof
- C/C++ 宏
offsetof
包含在头文件stddef.h
内置函数 Built-in Functions
__builtin_clz
int __builtin_clz(unsigned int x);
返回一个数的高位端的 0
的个数
__sync_val_compare_and_swap
type __sync_val_compare_and_swap (type *ptr, type oldval, type newval, ...)
内置的原子比较和交换操作,也就是说,如果 *ptr
的当前值是 oldval
, 则把 newval
写入 *ptr
, 并且返回写入前的 *ptr
值。