了解C11类型层次结构

Krz*_*icz 34 c standards types language-lawyer c11

我想完全理解C11语言的类型层次结构并以图形方式呈现它(树形图将是完美的).该标准没有提供任何关于这个问题的数字 - 有30个点描述了它们之间的各种类型和关系.我想画它.

我的尝试始于获得ISO/IEC 9899:201x委员会草案N1570并从文件第6.2.5节中提取所有必要的陈述.然后,我开始以树的形式重新安排知识.让我分两步介绍我的工作.

第1步:第1-15点

提取的知识(第6.2.5节+指定生产内的点):

  • 1 种类型 = 对象类型 + 函数类型 ;
  • 4个标准符号整型 = signed char,short int,int,long int,long long int;
  • 4个有符号整数类型 =标准有符号整数类型+ 扩展有符号整数类型 ;
  • 6个标准无符号整型 = _Bool,unsigned char,unsigned short int,unsigned int,unsigned long int,unsigned long long int;
  • 6个无符号整数类型 =标准无符号整数类型+ 扩展无符号整数类型 ;
  • 7种标准整数类型 =标准有符号整数类型+标准无符号整数类型;
  • 7个扩展整数类型 =扩展有符号整数类型+扩展无符号整数类型;
  • 10种实浮点类型 = float,double,long double;
  • 11种复杂类型 = float _Complex,double _Complex,long double _Complex;
  • 12种浮动类型 =真正的浮动类型+复杂类型;
  • 14种基本类型 = char+有符号整数类型+无符号整数类型+浮点类型;
  • 15种字符类型 = char,signed char,unsigned char.

由此产生的结构:

types
    object types
    function types
basic types
    char
    s?gned integer types
        standard s?gned integer types
            signed char, short int, int, long int, long long int
        extended s?gned integer types
    uns?gned integer types
        standard uns?gned integer types
            _Bool, unsigned char, unsigned short int, unsigned int,
            unsigned long int, unsigned long long int
        extended uns?gned integer types
    floating types
        real floating types
            float, double, long double
        complex types
            float _Complex, double _Complex, long double _Complex
standard integer types
    standard s?gned integer types
    standard uns?gned integer types
extended integer types
    extended s?gned integer types
    extended uns?gned integer types
character types
    char, signed char, unsigned char
Run Code Online (Sandbox Code Playgroud)

第2步:第16-24点

其余的陈述:

  • 16个枚举类型 ;
  • 17个整数类型 = char+有符号整数类型+无符号整数类型+枚举类型;
  • 17个真实类型 =整数类型+实际浮动类型;
  • 18种算术类型 =整数类型+浮动类型;
  • 20个派生类型 = 数组类型,结构类型,联合类型,函数类型,指针类型,原子类型 ;
  • 21个标量类型 =算术类型+指针类型;
  • 21个聚合类型 =数组类型+结构类型;
  • 24个派生的声明符类型 =数组类型+函数类型+指针类型.

最终的C11型系统结构:

types
    object types
    function types
basic types
    char
    s?gned integer types
        standard s?gned integer types
            signed char, short int, int, long int, long long int
        extended s?gned integer types
    uns?gned integer types
        standard uns?gned integer types
            _Bool, unsigned char, unsigned short int, unsigned int,
            unsigned long int, unsigned long long int
        extended uns?gned integer types
    floating types
        real floating types
            float, double, long double
        complex types
            float _Complex, double _Complex, long double _Complex
standard integer types
    standard s?gned integer types
    standard uns?gned integer types
extended integer types
    extended s?gned integer types
    extended uns?gned integer types
character types
    char, signed char, unsigned char
real types
    integer types
        char
        s?gned integer types
            standard s?gned integer types
                signed char, short int, int, long int, long long int
            extended s?gned integer types
        uns?gned integer types
            standard uns?gned integer types
                _Bool, unsigned char, unsigned short int, unsigned int,
                unsigned long int, unsigned long long int
            extended uns?gned integer types
        enumeration  types
    real floating types
        float, double, long double
scalar types
    arithmetic types
        integer types
            char
            s?gned integer types
                standard s?gned integer types
                    signed char, short int, int, long int, long long int
                extended s?gned integer types
            uns?gned integer types
                standard uns?gned integer types
                    _Bool, unsigned char, unsigned short int, unsigned int,
                    unsigned long int, unsigned long long int
                extended uns?gned integer types
            enumeration  types
        floating types
            real floating types
                float, double, long double
            complex types
                float _Complex, double _Complex, long double _Complex
    pointer types
derived types
    array types
    structure types
    un?on types
    function types
    pointer types
    atomic types
aggregate types
    array type
    structure type
derived declarator types
    array type
    structure type
    pointer type
Run Code Online (Sandbox Code Playgroud)

现在我需要减少结构(理想情况下是单个树)或找到一种更难以表示关系的方法.我想为C11打字系统提供一张漂亮的笔记本.有任何想法吗?

Krz*_*icz 16

通过删除/减少不太重要的节点并委托一些冗余/辅助信息通过其他方式呈现,可以简化由问题的第二步产生的C11类型的混乱结构.

我提出了以下五步算法:

  1. 删除所有扩展的整数类型(严格遵循假定的实现);
  2. 减少标准 整数类型(因为它们不再分区类型);
  3. 分组结构:
    1. 标量类型 VS 聚合类型对子树(表示为树),
    2. 基本类型 VS 派生类型对子树(由着色区域表示),
    3. 实数类型派生的声明符类型(表示为这些的描述子区域),
    4. 字符类型(用不同的文字颜色表示);
  4. 非标准生产的应用:对象类型 = 标量类型 + 聚合类型 ;
  5. 补充缺少的联合类型原子类型对象类型.

生成的C11类型系统摘要如下所示:

C11类型层次结构

引入灰色笔划/区域以增加树的可读性.

类型摘要不包括"类型声明完整性"的概念,因为它是在翻译单元内的特定点观察到的状态.在运行时,所有对象和函数都是完整类型的实例.该void类型是一个例外,但是,作为一个非类型(或指针的情况下的任何类型),它有意地从图中排除.

const,volatile,restrict_Atomic类型限定符违背其中,类型说明符派生类型,不能被递归地应用.这些的任何组合可以预先添加任何类型定义(只要它是有意义的).因此,将它们包括在图中会使其复杂化,同时不会引入任何合适的信息.表观例外使得_Atomic (type)构建体,其是考虑到作为一个类型说明符原子类型 -的一个派生类型的C11标准中列出.