C语言:volatile、const修饰的类型一行定义多个变量,变量的类型是什么?如何确定?

问题遇到的现象和发生背景

下面是我碰到的问题,虽然可以避免这种写法,但是我还是非常想知道这些在C语言标准中哪儿有说明,是属于那一块的知识不知道看什么解决问题,请求同志帮忙。

用代码块功能插入代码,请勿粘贴截图
int a,b,c;// a, b, c均为int
int * a,b,c;//a为int*,b, c为int
volatile int a,b,c; //a为volatile int,那么b,c呢
const int a,b,c; //a为const int,那么b,c呢
int const a,b,c;//a为const int,那么b,c呢

不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
理解和讨论之前请先学会如何观察!

//char (*(*x[3])())[5];//x是什么类型的变量?
//
//分析C语言声明,关键是搞清楚这个变量是个什么东西(函数、指针、数组),
//是函数那么剩下的就是他的参数和返回值,
//是指针那剩下部分是说明他指向什么,
//是数组剩下的部分就是说明数组的成员是什么类型。
//解析C语言声明规则:
//从左侧第一个标识符开始,按照优先级进行结合。*表示是..的指针,const表示只读的,volatile表示可变的,[]表示是数组,()表示是函数。
//
//x和[3]结合说明是一个大小为3的数组,该数组的每个元素为一类指针,该类指针指向一类函数,该类函数无参数,返回一类指针,该类指针指向一个大小为5的char型数组
#include <stdio.h>
#include <typeinfo.h>
char num[5];
char (*x00())[5] {
    return &num;
}
int main() {
    char (*(*x[3])())[5];//是个数组,大小为3
    char (*(*x0  )())[5];//数组的元素,是个函数指针
    char (*( x00 )())[5];//函数原型,参数为空,返回值为指针
    char (*  x000   )[5];//返回值

    x0 = x00;
    x[0] = x0;
    x[1] = x0;
    x[2] = x0;
    printf("typeid(x).name() is %s\n",typeid(x).name());
    return 0;
}
//typeid(x).name() is char (* (__cdecl**)(void))[5]


volatile int a,b,c; //a为volatile int,那么b,c呢 ---> a b c都是 volatile,
const int a,b,c; //a为const int,那么b,c呢 ---> a b c 都是 const int
int const a,b,c;//a为const int,那么b,c呢. ---> a b c 都是 const int
如果是指针会有点区别,可以去网上看看
可以用下面的代码验证:

    const int k=1,k1=1;
    int const k2=1,k3=1;

    k = 1;
    k1 = 1;
    k2 = 1;
    k3 =1;