Указатель на неконстантные данные может быть неявно преобразован в указатель на константные данные того же типа:
int *x = NULL;
int const *y = x;
Добавление дополнительных квалификаторов const для сопоставления с дополнительной косвенностью должно логически работать аналогично:
int * *x = NULL;
int *const *y = x; /* okay */
int const *const *z = y; /* warning */
Компиляция этого с GCC или Clang с флагом -Wall
, однако, приводит к следующему предупреждению:
test.c:4:23: warning: initializing 'int const *const *' with an expression of type
'int *const *' discards qualifiers in nested pointer types
int const *const *z = y; /* warning */
^ ~
Почему при добавлении дополнительного квалификатора const
"отбрасывать квалификаторы во вложенных типах указателей"?