6.4.4 常量

语法

1、constant:

integer-constant

floating-constant

enumeration-constant

character-constant

约束

2、每个常量应该具有一个类型并且一个常量的值应该在其类型可表示的值的范围内。

语义

3、每个常量具有一个类型,由其形式与值决定,稍后详细介绍。

6.4.4.1 整数常量

语法

1、integer-constant:

decimal-constant    integer-suffixopt

octal-constant    integer-suffixopt

hexadecimal-constant    integer-suffixopt

decimal-constant:

nonzero-digit

decimal-constant    digit

octal-constant:

0

octal-constant    octal-digit

    hexadecimal-constant:

        hexadecimal-prefix    hexadecimal-digit

        hexadecimal-constant    hexadecimal-digit

    hexadecimal-prefix:  以下之一

0x    0X

    nonzero-digit:  以下之一

1    2    3    4    5    6    7    8    9

octal-digit:  以下之一

0    1    2    3    4    5    6    7

hexadecimal-digit:  以下之一

0    1    2    3    4    5    6    7    8    9    a    b    c    d    e    f    A    B    C    D    E    F

integer-suffix:

unsigned-suffx    long-suffixopt

unsigned-suffx    long-long-suffixopt

long-suffix    unsigned-suffxopt

long-long-suffix    unsigned-suffxopt

unsigned-suffx:  以下之一

u    U

long-long-suffix:  以下之一

ll        LL

描述

2、一个整数常量以一个数字开头,但不具有小数点,也不具有指数部分。它可以具有一个前缀用来指定其基数,与一个后缀来指定其类型。

3、一个十进制常量以一个非零数字开头,并由一串十进制数构成。一个八进制常量由一个前缀0开头,后面可选地跟一串仅由07所组成的数字。一个十六进制常量由前缀0x0X构成,后面跟一串十进制数以及字母a(或A)到f(或F),分别表示10到15的值。

语义

4、一个十进制常量的值以基为10进行计算;一个八进制常量的值以基为8进行计算;一个十六进制常量以基为16进行计算。词法上第一个数字是最高有效位[译者注:即最左边的数字]。

5、一个整数常量的类型是相应列表中其值所能被表示的第一个。

6、如果一个整数常量不能用其列表中任一类型来表示,那么它可能具有一个扩展整数类型,如果该扩展整数类型可以表示其值。如果常量的列表中所有类型都是带符号的,那么扩展整数类型应该是带符号的。如果常量的列表中所有类型都是无符号的,那么扩展整数类型也应该是无符号的。如果列表同时包含了带符号与无符号类型,那么扩展整数类型可以具有带符号或无符号。如果一个整数常量不能用其列表中的任一类型来表示,并且也没有扩展整数类型,那么该整数常量不具有类型。

6.4.4.2 浮点常量

语法

1、float-constant:

decimal_floating-constant

hexadecimal-floating-constant

decimal-floating-constant:

fractional_constant    exponent-partopt    float-suffixopt

digit-sequence    exponent-part    float-suffixopt

hexadecimal-floating-constant:

hexadecimal-prefix    hexadecimal-fractional-constant    binary-exponent-part    float-suffixopt

        hexadecimal-prefix    hexadecimal-digit-sequence    binary-exponent-part    float-suffixopt

fractional-constant:

digit-sequenceopt    .    digit-sequence

digit-sequence    .

exponent-part:

e    signopt    digit-sequence

        E    signopt    digit-sequence

sign:  以下之一

+    -

digit-sequence:

digit

digit-sequence    digit

hexadecimal-fractional-constant:

hexadecimal-digit-sequenceopt    .    hexadecimal-digit-sequence

hexadecimal-digit-sequence    .

binary-exponent-part:        p    signopt    digit-sequence

        P    signopt    digit-sequence

   hexadecimal-digit-sequence:

hexadecimal-digit

hexadecimal-digit-sequence    hexadecimal-digit

float-suffix:  以下之一

f    l    F    L

描述

2、一个浮点常量具有一个尾数部分,它可以跟在一个指数部分后面,并且也可以有一个后缀来指定其类型。尾数部分的成员可包括一个表示整数部分的数字序列,后面跟小数点(.),后面再跟表示小数部分的数字序列。指数部分的分量为一个eEpP,后面跟由一个可选的带符号数字序列所组成的一个指数。整数部分或小数部分均可缺省;对于十进制浮点常量,小数点或指数部分必须存在其中之一。

语义

3、尾数部分被解释为一个(十进制或十六进制的)有理数;指数部分中的数字序列被解释为一个十进制整数。对于十进制浮点常量,指数指明了10的幂,尾数部分作为它的被乘数。对于十六进制浮点常量,指数指明了2的幂,尾数部分作为它的被乘数。对于十进制浮点常量,以及对于十六进制浮点常量,当FLT_RADIX不为2的幂时,结果要么取最接近可表示的值,要么大于或小于毗邻最近可表示值,如何选择由实现自定义的方式进行。对于十六进制浮点常量,当FLT_RADIX是一个2的幂时,结果被正确地舍入。

4、一个没有后缀的浮点常量具有类型double。如果后缀字母为fF,那么它具有类型float。如果后缀字母为lL,那么它具有类型long double

5、浮点常量被转换为内部格式,就好比在翻译时。一个浮点常量的转换在执行时不应该引发一个异常情况或一个浮点异常。所有相同源形式的浮点常量[注:1.23,1.230,123e-2,123e-02,以及1.23L都是不同的源形式,从而不需要转换为相同的内部格式与值。]应该转换为相同的内部格式,并具有相同的值。

推荐实践

6、如果一个十进制常量不能完全用其计算格式来表示,那么实现应该产生一个诊断消息;实现然后应该将程序的翻译继续执行下去。

7、浮点常量的编译时转换应该通过库函数来匹配字符串的执行时转换,诸如strtod,给定适用于两者转换、相同的结果格式以及默认执行时舍入的匹配输入。[注:用于库函数的规格说明建议比起对于浮点常量的要求更精确的转换。]

6.4.4.3 枚举常量

语法

1、enumeration-constant:

identifier

语义

2、声明为一个枚举常量的一个标识符具有类型int

6.4.4.4 字符常量

语法

1、character-constant:

' c-char-sequence '

L' c-char-sequence '

u' c-char-sequence '

U' c-char-sequence '

c-char-sequence:

c-char

c-char-sequence    c-char

c-char:

源字符集的任一成员,除了单引号 ' ,倒斜杠 \ ,或换行字符

escape-sequence

escape-sequence:

simple-escape-sequence

octal-escape-sequence

hexadecimal-escape-sequence

universal-escape-name

simple-escape-sequence: 以下之一

  \'    \"    \?    \\    \a    \b    \f    \n    \r    \t    \v

octal-escape-sequence:

\  octal-digit

\  octal-digit    octal-digit

\  octal-digit    octal-digit    octal-digit

\  octal-digit    octal-digit    octal-digit    octal-digit

hexadecimal-escape-sequence:

\x  hexadecimal-digit

hexadecimal-escape-sequence    hexadecimal-digit

描述

2、一个整数常量是被一对单引号封闭住的一个或多个多字节字符序列,比如'x'。一个宽字符常量也同样如此,除了带有前缀字母LuU。序列的元素是源字符集的任一成员,有一些例外稍后会详细描述;它们以实现定义的形式映射到执行字符集的成员。

3、单引号 ' ,双引号 " ,问好 ? ,倒斜杠 \ ,以及任意的整数值根据以下转义序列表来表示:

单引号 '    \'

双引号 "    \"

问号 ?      \?

倒斜杠 \    \\

八进制字符    \octal digits

十六进制字符    \x hexadecimal digits

4、双引号 " 与问好 ? 亦或可以用它们自身来表示,亦或可以分别用转义符 \"\? 来表示,但是单引号 ' 与倒斜杠 \ 应该分别用转义符 \'\\ 来表示。

5、在一个八进制转义序列中,跟在倒斜杠之后的八进制数字为一个整型字符常量被取为构造一单个字符的一部分,或为一个宽字符常量被取为构造一单个宽字符的一部分。如此所形成的八进制整数的数值指定了所期望的字符的值或宽字符的值。

6、在一个十六进制转义序列中,跟在倒斜杠之后的十六进制数字一记字母x被取为为一个整型字符常量构造一单个字符的一部分,或为一个宽字符常量构造一单个宽字符的一部分。如此形成的十六进制整数的数值指定了所期望的宽字符的字符。

7、每个八进制或十六进制转义序列是可以组成转义序列的最长序列。

8、此外,不在基本字符集中的字符是可以通过通用字符名来表示的,并且某些非可显字符可以用转义序列来表示,通过倒斜杠后面跟一个小写字母:\a\b\f\n\r\t,以及\v。[注:这些字符的语义在5.2.2中被讨论。如果任何其它字符后面跟在一个倒斜杠后面,那么结果不是一个标记,并且需要一个诊断。见“未来的语言方向”(6.11.4)。]

约束

9、一个八进制或十六进制转义序列的值应该在相应类型的可表示值的范围内:

前缀        相应类型

无            unsigned char

L            相应于wchar_t的无符号类型

u            char16_t

U            char32_t

语义

10、一个整型字符常量具有类型int。一个包含射到一单字节执行字符的一单个字符的整型字符常量的值是被解释为一个整数的被映射字符所表示的数值。含有多个字符的一个整型字符常量(比如'ab')的值,或是包含一个字符或转义序列的整型字符常量的值——它们不映射到一单字节执行字符——,是由实现定义的。如果一个整型字符常量包含一单个字符或转义序列,那么其值的结果为,当带有类型char的一个对象,其值为单个字符或转义序列而被转换为类型int

11、带有前缀字母L的一个宽字符常量具有类型wchar_t,定义在<stddef.h>头文件中的一个整数类型;带有前缀字母uU的一个宽字符常量分别具有类型char16_tchar32_t,定义在<uchar.h>头文件中的无符号整数类型。包含一单个多字节字符(该多字节字符映射到扩展执行字符集的一单个成员)的一个宽字符常量的值是相应于那个多字节字符的宽字符,通过mbtowcmbrtoc16mbrtoc32函数来定义,根据其实际类型来定,带有实现定义的当前本地语言。包含多个多字节字符或一单个多字节字符(映射到扩展执行字符集的多个成员)的一个宽字符常量值,或是包含一不在扩展执行字符集中表示的多字节字符或转义序列的一个宽字符常量,是由实现定义的。

12、例1  '\0' 的构造通常用于表示空字符。

13、例2  考虑对整数以及具有char类型的八位对象使用2的取反表示。在某个实现中,如果类型char具有与signed char相同范围的值,那么整型字符常量 '\xFF' 具有值-1;如果类型char具有与unsigned char相同范围的值,那么字符常量 '\xFF' 具有值+255

14、例3  即使八比特被用于具有char类型的对象,构造 '\x123' 指定了仅包含一单个字符的一个整数字符常量,由于一个十六进制转义序列仅被一个非十六进制字符终止。为了指定一个包含两个字符的整型字符常量,它们的值分别为'\x12''3',构造 '\0223' 可以被使用,由于一个八进制转义序列在三个八进制数字之后被终止。(这个双字符整型字符常量是由实现定义的。)

15、例4  即使有12或更多比特用于具有类型wchar_t的对象,L'\1234'指定了实现定义的值,该值通过0123的值与'4'的值的组合得到。

ISO/IEC 9899:2011 条款6.4.4——常量的更多相关文章

  1. ISO/IEC 9899:2011 条款3——术语、定义与符号

    3. 术语.定义与符号 1.对于此国际标准的意图,应用了以下定义.其它术语是在用斜体类型或一个语法规则左侧出现的地方定义.在本国际标准中所显式定义的术语不被假定为对其它地方所定义的类似术语的隐式引用. ...

  2. ISO/IEC 9899:2011 条款5——5.2.1 字符集

    5.2.1 字符集 1.两个字符集和它们相关联的依次顺序应该被定义:写在源文件中的集合(源字符集),以及在执行环境中被解释的集合(执行字符集).每个集合此外被划分为一个基本字符集,其内容由本子条款给出 ...

  3. ISO/IEC 9899:2011 条款6.4.2——标识符

    6.4.2 标识符 6.4.2.1 通用 语法 1.identifier: identifier-nodigit identifier    identifier-nondigit identifie ...

  4. ISO/IEC 9899:2011 条款6.4.3——通用字符名

    6.4.3 通用字符名 语法 1.通用字符名: universal_character-name: \u hex-quad(四位十六进制数) \U hex-quad hex-quad hex-quad ...

  5. ISO/IEC 9899:2011 条款5——5.1.2 执行环境

    5.1.2 执行环境 1.定义了两个执行环境:独立式(freestanding)以及宿主的(hosted).在这两种情况下,当一个派定的C函数被执行环境调用时,程序就启动.所有具有静态存储周期的对象应 ...

  6. ISO/IEC 9899:2011 条款4——标准顺从

    4. 标准顺从 1.在本国际标准中,“应该”被解释为对一个实现或一个程序的要求:相反地,“不该”被解释为禁用. 2.如果违反了出现在一个强制规定或运行时强制规定之外的“应该”或“不该”要求,那么该行为 ...

  7. ISO/IEC 9899:2011 条款6——语言

    6 语言 6.1 标记法 1.在本条款中所使用的语法标记法.语义类别(非终结符)用斜体字指示,而字面量单词以及字符集成员(终结符)用粗体字指示.跟在一个非终结符后面的冒号(:)引出其定义.在单独的行中 ...

  8. ISO/IEC 9899:2011 条款6.3——转换

    6.3 转换 1.有些操作符将操作数的值自动地从一种类型转换为另一种.本子条款指定了从这么一个隐式转换所要求的结果,以及从一个投射操作(一个显式转换)所要求的结果.在6.3.1.8中所列出的信息概括了 ...

  9. ISO/IEC 9899:2011 条款6.5——表达式

    6.5 表达式 1.一个表达式是操作符与操作数的一个序列,这些操作符与操作数指定了一个值的计算,或指派一个对象或一个函数,或是生成副作用,或执行上述操作的组合.对一个操作符的操作数的值计算顺序排在对该 ...

随机推荐

  1. linux网络编程之简单的线程池实现

    转眼间离15年的春节越来越近了,还有两周的工作时间貌似心已经不在异乡了,期待与家人团聚的日子,当然最后两周也得坚持站好最后一班岗,另外期待的日子往往是心里不能平静的,越是想着过年,反而日子过得越慢,于 ...

  2. Jenkins 参数化构建(Git Parameter)

    由于我们在测试过程中,可能需要在多个测试环境跑用例,这个时候就需要jenkins参数化了. Jenkins参数化一般常用的有两种方式:Choice和String Parameter两种 (1)Choi ...

  3. py停止工作

    # 参考https://blog.csdn.net/w952470866/article/details/79132955 电脑搬动换了网络后打开pycharm显示停止工作解决办法: 将python. ...

  4. 分页器,序列化组件,bulk_create,choices字段

    分页器 <!--前端--> {% for book in page_queryset %} <p>{{ book.title }}</p> {% endfor %} ...

  5. c语言数组越界的避免方法

    1.尽量显式地指定数组的边界 #define MAX 10 - int a[MAX]={1,2,3,4,5,6,7,8,9,10}; 在 C99 标准中,还允许我们使用单个指示符为数组的两段" ...

  6. Spring Cloud 功能使用的层面组件(一)

    来源:赤峰seo 实际上,Spring Cloud 是一个全家桶式的技术栈,它包含了很多组件.本文先从最核心的几个组件,也就是 Eureka.Ribbon.Feign.Hystrix.Zuul 入手 ...

  7. pycharm鼠标更改字体大小

    Pycharm快捷键设置(鼠标滚动控制字体大小) 一.pycharm字体放大的设置 File -> setting -> Keymap ->在搜寻框中输入:increase -> ...

  8. [51Nod 1238] 最小公倍数之和 (恶心杜教筛)

    题目描述 求∑i=1N∑j=1Nlcm(i,j)\sum_{i=1}^N\sum_{j=1}^Nlcm(i,j)i=1∑N​j=1∑N​lcm(i,j) 2<=N<=10102<=N ...

  9. 原生JS实现简易随机点名功能

    定时器的工作原理,这里将用引用How JavaScript Timers Work中的例子来解释定时器的工作原理,该图为一个简单版的原理图.· 上图中,左侧数字代表时间,单位毫秒:左侧文字代表某一个操 ...

  10. Python2.7学习

    网上很多代码都不适用于python3版本,所以还是转回版本2来学习了 install 安装模块特别简单 E:\01_SOFT\Python27\python  -m easy_install sunb ...