签入预处理号

Sign in Preprocessing Number

本文关键字:预处理      更新时间:2023-10-16

在c++标准14 ([lex.ppnumber])的2.10节中,预处理数被定义为

pp-number
    digit
    . digit
    pp-number digit
    pp-number ' digit
    pp-number ' nondigit
    pp-number identifier-nondigit
    pp-number e sign
    pp-number E sign
    pp-number .

所以这应该包括所有的整数字面值和浮点字面值。但在2.14.4 ([lex.fcon])中,有一个符号是可选的,即(如果有一种方法可以将其格式化为标准格式,请随意改进)。

exponent-part:
    e sign_opt digit-sequence
    E sign_opt digit-sequence
sign: one of
    + -

为什么pp-number定义中的符号不是可选的?事实上,按照它的编写方式,数字1e3应该作为浮点数有效,而不是作为pp数有效,这与下面2.10节给出的解释相矛盾。

有什么我不明白的吗?

从这里引用:

预处理数有一个相当奇怪的定义。类别包括所有普通的整型和浮点型常量人们对C的期望,但也有一些其他的事情,人们可能不会最初被认为是一个数字。正式地,预处理数字开始使用可选的句点,所需的十进制数字,然后继续任意字母、数字、下划线、句号和指数。指数是两个字符序列' e+ ', ' e- ', ' e+ ',' E- ', ' p+ ', ' p- ', ' p+ '和' p- '。(以p开头的指数或' P '是C99的新成员。它们用于十六进制浮点数常数。)

这个不同寻常的定义的目的是将预处理器与数字常量的全部复杂性隔离开来。是的不必区分词法有效和无效浮点数,这很复杂。这个定义也是允许您在任何位置拆分标识符并恰好得到两个令牌,然后可以将其与' ## '操作符粘贴在一起。

预处理数字可能会导致程序出错误解。例如,0xE+12是一个预处理数不能转换为任何有效的数字常量,因此是语法错误。它不是指0xE + 12,这是你可能有的目的。

数字"实际上是一个有效的预处理数。你没有正确阅读语法所暗示的内容。一个数字,后面跟着一个非数字的标识符(在本例中是一个字母),后面跟着一个数字,这确实符合语法。