Gcc 为什么默认情况下定义了_GNU_SOURCE?如何关闭它?

Gcc 为什么默认情况下定义了_GNU_SOURCE?如何关闭它?,gcc,Gcc,我正在使用g++,它告诉我我在命令行上定义了\u GNU\u SOURCE,但我没有 我现在知道可以使用定义\u GNU\u SOURCE来启用GNU扩展,但现在我不想要这些扩展。我添加了-std=c++0x-pedantic,但是\u GNU\u SOURCE仍然是定义 g++-v的输出如下: $ g++ -v Using built-in specs. COLLECT_GCC=/usr/bin/g++ COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux

我正在使用g++,它告诉我我在命令行上定义了
\u GNU\u SOURCE
,但我没有

我现在知道可以使用定义
\u GNU\u SOURCE
来启用GNU扩展,但现在我不想要这些扩展。我添加了
-std=c++0x-pedantic
,但是
\u GNU\u SOURCE
仍然是定义

g++-v
的输出如下:

$ g++ -v
Using built-in specs.
COLLECT_GCC=/usr/bin/g++
COLLECT_LTO_WRAPPER=/usr/lib/gcc/x86_64-linux-gnu/4.6/lto-wrapper
Target: x86_64-linux-gnu
Configured with: ../src/configure -v --with-pkgversion='Ubuntu/Linaro 4.6.3-1ubuntu5' --with-bugurl=file:///usr/share/doc/gcc-4.6/README.Bugs --enable-languages=c,c++,fortran,objc,obj-c++ --prefix=/usr --program-suffix=-4.6 --enable-shared --enable-linker-build-id --with-system-zlib --libexecdir=/usr/lib --without-included-gettext --enable-threads=posix --with-gxx-include-dir=/usr/include/c++/4.6 --libdir=/usr/lib --enable-nls --with-sysroot=/ --enable-clocale=gnu --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-gnu-unique-object --enable-plugin --enable-objc-gc --disable-werror --with-arch-32=i686 --with-tune=generic --enable-checking=release --build=x86_64-linux-gnu --host=x86_64-linux-gnu --target=x86_64-linux-gnu
Thread model: posix
gcc version 4.6.3 (Ubuntu/Linaro 4.6.3-1ubuntu5)
当我给它一个空文件并用
g++-E-dD-std=c++98-pedantic empty.cpp
编译时,我得到以下结果:

$ g++ -E -dD -std=c++98 -pedantic empty.cpp
# 1 "empty.cpp"
# 1 "<built-in>"
#define __STDC__ 1
#define __cplusplus 1
#define __STDC_HOSTED__ 1
#define __GNUC__ 4
#define __GNUC_MINOR__ 6
#define __GNUC_PATCHLEVEL__ 3
#define __VERSION__ "4.6.3"
#define __FINITE_MATH_ONLY__ 0
#define _LP64 1
#define __LP64__ 1
#define __SIZEOF_INT__ 4
#define __SIZEOF_LONG__ 8
#define __SIZEOF_LONG_LONG__ 8
#define __SIZEOF_SHORT__ 2
#define __SIZEOF_FLOAT__ 4
#define __SIZEOF_DOUBLE__ 8
#define __SIZEOF_LONG_DOUBLE__ 16
#define __SIZEOF_SIZE_T__ 8
#define __CHAR_BIT__ 8
#define __BIGGEST_ALIGNMENT__ 16
#define __ORDER_LITTLE_ENDIAN__ 1234
#define __ORDER_BIG_ENDIAN__ 4321
#define __ORDER_PDP_ENDIAN__ 3412
#define __BYTE_ORDER__ __ORDER_LITTLE_ENDIAN__
#define __FLOAT_WORD_ORDER__ __ORDER_LITTLE_ENDIAN__
#define __SIZEOF_POINTER__ 8
#define __GNUG__ 4
#define __SIZE_TYPE__ long unsigned int
#define __PTRDIFF_TYPE__ long int
#define __WCHAR_TYPE__ int
#define __WINT_TYPE__ unsigned int
#define __INTMAX_TYPE__ long int
#define __UINTMAX_TYPE__ long unsigned int
#define __CHAR16_TYPE__ short unsigned int
#define __CHAR32_TYPE__ unsigned int
#define __SIG_ATOMIC_TYPE__ int
#define __INT8_TYPE__ signed char
#define __INT16_TYPE__ short int
#define __INT32_TYPE__ int
#define __INT64_TYPE__ long int
#define __UINT8_TYPE__ unsigned char
#define __UINT16_TYPE__ short unsigned int
#define __UINT32_TYPE__ unsigned int
#define __UINT64_TYPE__ long unsigned int
#define __INT_LEAST8_TYPE__ signed char
#define __INT_LEAST16_TYPE__ short int
#define __INT_LEAST32_TYPE__ int
#define __INT_LEAST64_TYPE__ long int
#define __UINT_LEAST8_TYPE__ unsigned char
#define __UINT_LEAST16_TYPE__ short unsigned int
#define __UINT_LEAST32_TYPE__ unsigned int
#define __UINT_LEAST64_TYPE__ long unsigned int
#define __INT_FAST8_TYPE__ signed char
#define __INT_FAST16_TYPE__ long int
#define __INT_FAST32_TYPE__ long int
#define __INT_FAST64_TYPE__ long int
#define __UINT_FAST8_TYPE__ unsigned char
#define __UINT_FAST16_TYPE__ long unsigned int
#define __UINT_FAST32_TYPE__ long unsigned int
#define __UINT_FAST64_TYPE__ long unsigned int
#define __INTPTR_TYPE__ long int
#define __UINTPTR_TYPE__ long unsigned int
#define __GXX_WEAK__ 1
#define __DEPRECATED 1
#define __GXX_RTTI 1
#define __EXCEPTIONS 1
#define __GXX_ABI_VERSION 1002
#define __SCHAR_MAX__ 127
#define __SHRT_MAX__ 32767
#define __INT_MAX__ 2147483647
#define __LONG_MAX__ 9223372036854775807L
#define __LONG_LONG_MAX__ 9223372036854775807LL
#define __WCHAR_MAX__ 2147483647
#define __WCHAR_MIN__ (-__WCHAR_MAX__ - 1)
#define __WINT_MAX__ 4294967295U
#define __WINT_MIN__ 0U
#define __PTRDIFF_MAX__ 9223372036854775807L
#define __SIZE_MAX__ 18446744073709551615UL
#define __INTMAX_MAX__ 9223372036854775807L
#define __INTMAX_C(c) c ## L
#define __UINTMAX_MAX__ 18446744073709551615UL
#define __UINTMAX_C(c) c ## UL
#define __SIG_ATOMIC_MAX__ 2147483647
#define __SIG_ATOMIC_MIN__ (-__SIG_ATOMIC_MAX__ - 1)
#define __INT8_MAX__ 127
#define __INT16_MAX__ 32767
#define __INT32_MAX__ 2147483647
#define __INT64_MAX__ 9223372036854775807L
#define __UINT8_MAX__ 255
#define __UINT16_MAX__ 65535
#define __UINT32_MAX__ 4294967295U
#define __UINT64_MAX__ 18446744073709551615UL
#define __INT_LEAST8_MAX__ 127
#define __INT8_C(c) c
#define __INT_LEAST16_MAX__ 32767
#define __INT16_C(c) c
#define __INT_LEAST32_MAX__ 2147483647
#define __INT32_C(c) c
#define __INT_LEAST64_MAX__ 9223372036854775807L
#define __INT64_C(c) c ## L
#define __UINT_LEAST8_MAX__ 255
#define __UINT8_C(c) c
#define __UINT_LEAST16_MAX__ 65535
#define __UINT16_C(c) c
#define __UINT_LEAST32_MAX__ 4294967295U
#define __UINT32_C(c) c ## U
#define __UINT_LEAST64_MAX__ 18446744073709551615UL
#define __UINT64_C(c) c ## UL
#define __INT_FAST8_MAX__ 127
#define __INT_FAST16_MAX__ 9223372036854775807L
#define __INT_FAST32_MAX__ 9223372036854775807L
#define __INT_FAST64_MAX__ 9223372036854775807L
#define __UINT_FAST8_MAX__ 255
#define __UINT_FAST16_MAX__ 18446744073709551615UL
#define __UINT_FAST32_MAX__ 18446744073709551615UL
#define __UINT_FAST64_MAX__ 18446744073709551615UL
#define __INTPTR_MAX__ 9223372036854775807L
#define __UINTPTR_MAX__ 18446744073709551615UL
#define __FLT_EVAL_METHOD__ 0
#define __DEC_EVAL_METHOD__ 2
#define __FLT_RADIX__ 2
#define __FLT_MANT_DIG__ 24
#define __FLT_DIG__ 6
#define __FLT_MIN_EXP__ (-125)
#define __FLT_MIN_10_EXP__ (-37)
#define __FLT_MAX_EXP__ 128
#define __FLT_MAX_10_EXP__ 38
#define __FLT_DECIMAL_DIG__ 9
#define __FLT_MAX__ 3.40282346638528859812e+38F
#define __FLT_MIN__ 1.17549435082228750797e-38F
#define __FLT_EPSILON__ 1.19209289550781250000e-7F
#define __FLT_DENORM_MIN__ 1.40129846432481707092e-45F
#define __FLT_HAS_DENORM__ 1
#define __FLT_HAS_INFINITY__ 1
#define __FLT_HAS_QUIET_NAN__ 1
#define __DBL_MANT_DIG__ 53
#define __DBL_DIG__ 15
#define __DBL_MIN_EXP__ (-1021)
#define __DBL_MIN_10_EXP__ (-307)
#define __DBL_MAX_EXP__ 1024
#define __DBL_MAX_10_EXP__ 308
#define __DBL_DECIMAL_DIG__ 17
#define __DBL_MAX__ double(1.79769313486231570815e+308L)
#define __DBL_MIN__ double(2.22507385850720138309e-308L)
#define __DBL_EPSILON__ double(2.22044604925031308085e-16L)
#define __DBL_DENORM_MIN__ double(4.94065645841246544177e-324L)
#define __DBL_HAS_DENORM__ 1
#define __DBL_HAS_INFINITY__ 1
#define __DBL_HAS_QUIET_NAN__ 1
#define __LDBL_MANT_DIG__ 64
#define __LDBL_DIG__ 18
#define __LDBL_MIN_EXP__ (-16381)
#define __LDBL_MIN_10_EXP__ (-4931)
#define __LDBL_MAX_EXP__ 16384
#define __LDBL_MAX_10_EXP__ 4932
#define __DECIMAL_DIG__ 21
#define __LDBL_MAX__ 1.18973149535723176502e+4932L
#define __LDBL_MIN__ 3.36210314311209350626e-4932L
#define __LDBL_EPSILON__ 1.08420217248550443401e-19L
#define __LDBL_DENORM_MIN__ 3.64519953188247460253e-4951L
#define __LDBL_HAS_DENORM__ 1
#define __LDBL_HAS_INFINITY__ 1
#define __LDBL_HAS_QUIET_NAN__ 1
#define __DEC32_MANT_DIG__ 7
#define __DEC32_MIN_EXP__ (-94)
#define __DEC32_MAX_EXP__ 97
#define __DEC32_MIN__ 1E-95DF
#define __DEC32_MAX__ 9.999999E96DF
#define __DEC32_EPSILON__ 1E-6DF
#define __DEC32_SUBNORMAL_MIN__ 0.000001E-95DF
#define __DEC64_MANT_DIG__ 16
#define __DEC64_MIN_EXP__ (-382)
#define __DEC64_MAX_EXP__ 385
#define __DEC64_MIN__ 1E-383DD
#define __DEC64_MAX__ 9.999999999999999E384DD
#define __DEC64_EPSILON__ 1E-15DD
#define __DEC64_SUBNORMAL_MIN__ 0.000000000000001E-383DD
#define __DEC128_MANT_DIG__ 34
#define __DEC128_MIN_EXP__ (-6142)
#define __DEC128_MAX_EXP__ 6145
#define __DEC128_MIN__ 1E-6143DL
#define __DEC128_MAX__ 9.999999999999999999999999999999999E6144DL
#define __DEC128_EPSILON__ 1E-33DL
#define __DEC128_SUBNORMAL_MIN__ 0.000000000000000000000000000000001E-6143DL
#define __REGISTER_PREFIX__
#define __USER_LABEL_PREFIX__
#define _FORTIFY_SOURCE 2
#define __GNUC_GNU_INLINE__ 1
#define __NO_INLINE__ 1
#define __STRICT_ANSI__ 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_1 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_2 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_4 1
#define __GCC_HAVE_SYNC_COMPARE_AND_SWAP_8 1
#define __GCC_HAVE_DWARF2_CFI_ASM 1
#define __PRAGMA_REDEFINE_EXTNAME 1
#define __SSP__ 1
#define __SIZEOF_INT128__ 16
#define __SIZEOF_WCHAR_T__ 4
#define __SIZEOF_WINT_T__ 4
#define __SIZEOF_PTRDIFF_T__ 8
#define __amd64 1
#define __amd64__ 1
#define __x86_64 1
#define __x86_64__ 1
#define __k8 1
#define __k8__ 1
#define __MMX__ 1
#define __SSE__ 1
#define __SSE2__ 1
#define __SSE_MATH__ 1
#define __SSE2_MATH__ 1
#define __gnu_linux__ 1
#define __linux 1
#define __linux__ 1
#define __unix 1
#define __unix__ 1
#define __ELF__ 1
#define __DECIMAL_BID_FORMAT__ 1
# 1 "<command-line>"
#define _GNU_SOURCE 1
# 1 "empty.cpp"
$g++-E-dD-std=c++98-pedantic empty.cpp
#1“empty.cpp”
# 1 ""
#定义u STDC_uu_uu1
#定义cplusplus 1
#定义STDC托管的1
#定义
#定义小调
#定义GNUC补丁级别3
#定义版本4.6.3
#仅定义有限数学0
#定义LP64 1
#定义
#定义内部的大小4
#定义长度的大小8
#定义长的大小8
#定义短尺寸2
#定义浮点数的大小4
#定义双精度的大小8
#定义长双圈的大小16
#定义大小的大小8
#定义字符位8
#定义最大对齐16
#定义uuu顺序u小u末端uuuuu 1234
#定义u u顺序u大u末端_uuu4321
#定义顺序PDP ENDIAN 3412
#定义字节顺序顺序顺序小端__
#定义浮点数单词顺序顺序小尾数__
#定义指针的大小
#定义
#定义大小类型长无符号整数
#定义\uu PTRDIFF\u类型\uuuu长整型
#定义\uuuuwchar\uuuuu类型\uuuuuuu int
#定义无符号整数
#定义整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型
#定义_UINTMAX_类型_长无符号整数
#定义\uuuu字符16\u类型\uuuuu短无符号整数
#定义字符32类型无符号整数
#定义信号原子类型
#定义签名字符
#定义\uuuuInt16\u类型\uuuuuu短整型
#定义\uuuu INT32\u类型\uuuuu int
#定义\uuuu int 64\u类型\uuuuu长int
#定义无符号字符
#定义uuuint16_uuuu类型uuuuu短无符号整数
#定义无符号整数
#定义长无符号整数
#定义签名字符
#定义uuu INT u LEAST16 u TYPE uuuu短INT
#定义\uuuu INT \u至少32 \u类型\uuuuu INT
#定义长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度长度
#定义\uuuu UINT\u LEAST8\u类型\uuuu无符号字符
#定义uuu UINT u LEAST16 u TYPE uuuu短无符号整数
#定义不带符号的整数
#定义长无符号整数
#定义有符号字符
#定义\uuuu INT\uFast16\u类型\uuuuu长INT
#定义\uuuu INT\uFast32\u类型\uuuuu长INT
#定义\uuuu INT\uFast64\u类型\uuuuu长INT
#定义无符号字符
#定义长无符号整数
#定义长无符号整数
#定义长无符号整数
#定义整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型整型
#定义_uintpttr_类型_长无符号整数
#定义_ugxx_u弱_uu1
#定义\uu不推荐1
#定义\uuuugxx\uRTTI 1
#定义例外情况1
#定义\uuuugxx\uABI\u1002版
#定义\uuuu SCHAR\u MAX\uuuuuuu 127
#定义SHRT最大值32767
#定义\uuuuu INT\uu MAX\uuuuuuu 2147483647
#定义长度最大值9223372036854775807L
#定义_ulong_ulong_MAX__u9223372036854775807LL
#定义uuu WCHAR_uumax_uuuuuu2147483647
#定义uuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuhar\uuuuumax\uuuuuuuuu1)
#定义最大值为4294967295U
#定义
#定义uuu PTRDIFF_uuumax_uuuuuu23372036854775807L
#定义尺寸最大值18446744073709551615UL
#定义uuu INTMAX_uuumax_uuuuu9223372036854775807L
#定义uu INTMAX_uc(C)C##L
#定义最大值为18446744073709551615UL
#定义uu UINTMAX_uc(C)C##UL
#定义信号原子最大值2147483647
#定义uuu信号u原子uuu最小uuuu(---uuuuu信号u原子uu最大uuuu-1)
#定义最大值为127
#定义\uuuuu INT16\uu MAX\uuuuuuuu 32767
#定义\uuuuu INT32\uuu MAX\uuuuuuuu 2147483647
#定义uuu INT64_uuumax_uuuuuu9223372036854775807L
#定义最大值为255
#定义UINT16最大值65535
#定义最大值为4294967295U
#定义最大值18446744073709551615UL
#定义最小值8最大值127
#定义uuu INT8_uc(C)C
#定义至少16个最大值32767
#定义uuu INT16_uc(C)C
#定义至少32个最大值2147483647
#定义uuu INT32_uc(C)C
#定义最小值64最大值9223372036854775807L
#定义uu INT64_uc(C)C##L
#定义最小值8最大值255
#定义uuu UINT8_uc(C)C
#定义最小值16最大值65535
#定义uu UINT16_uc(C)C
#定义至少32个最大值4294967295U
#定义U UINT32_C(C)C##U
#定义至少64个最大值18446744073709551615UL
#定义uu UINT64_uc(C)C##UL
#定义内部快速8最大值127
#定义uuu INT_FAST16_MAX_uuuuu9223372036854775807L
#定义uuu INT_FAST32_MAX_uuuuu9223372036854775807L
#定义uuu INT_FAST64_MAX_uuuuu9223372036854775807L
#定义快速8最大值255
#定义快速16最大值18446744073709551615UL
#定义快速32最大值18446744073709551615UL
#定义快速64最大值18446744073709551615UL
#定义uuu INTPTR_uumax_uuuuu9223372036854775807L
#定义最大值18446744073709551615UL
#定义\uuuu FLT\u EVAL\u方法\uuuu0
#定义评估方法2
#定义基函数2
#定义FLT MANT DIG 24
#定义FLT挖掘6
#定义_uflt_umin_uexp_uu(-125)
#定义最小值10经验值(-37)
#定义FLT最大值EXP 128
#定义FLT最大值10经验值38
#定义uuu FLT u DECIMAL uu DIG uuuu9
#定义uuu FLT_uumax_uuuuuuu3.40282346638528859812e+38F
#定义uuu FLT_uumin_uuuuu1.1754943508228750797E-38F
#定义ε1.1920928955078125000E-7F
#定义定义1.40129846432481707092e-45F
#定义\uuu FLT\u有\uu DENORM\uuuuu 1
#定义u FLT_有u无穷大uu 1
#定义\uuu FLT\u有\uu QUIET\uu NAN\uuuuu 1
#定义DBL MANT DIG 53
#定义DBL挖掘15
#定义DBL最小经验(-1021)
#定义DBL最小值10经验值(-307)
#定义\uuuu DBL\umax\uexp\uuuu1024
#定义DBL最大值10经验308
#定义DBL十进制数据挖掘17
#定义双精度(1.79769313486231570815e+308L)
#定义双精度(2.22507385850720138309e-308L)
#定义DBLεdouble(2.22044604925031308085e-16L)
#定义双精度(4.94065645841246544177e-324L)
#define u DBL u有DENORM uu 1
#define u DBL_有u无穷大uu 1
#define uu DBL u HAS u QUIET u NAN uuu 1
#定义\uuuu LDBL\uu MANT\uu DIG\uuuu 64
#定义LDBL挖掘18
#定义\uuuuLDBL\uMin\uExp\uuuu1(-16381)
#定义最小值10经验值(-4931)
#蔑视