Вы можете представить это объявление
const char* a = "Anthony";
следующим образом
const char string_literal[] = "Anthony";
const char *a = string_literal;
То есть компилятор создает массив символов со статикой c длительности хранения, в котором хранится строка "Anthony"
и адрес первого символа массива (из-за неявного преобразования указателей массива в указатели на их первые символы) назначается указателю a
.
Вот демонстрационная программа, которая показывает, что строковые литералы являются символьными массивами.
#include <iostream>
#include <type_traits>
decltype( auto ) f()
{
return ( "Anthony" );
}
template <size_t N>
void g( const char ( &s )[N] )
{
std::cout << s << '\n';
}
int main()
{
decltype( auto ) r = f();
std::cout << "The size of the referenced array is "
<< std::extent<std::remove_reference<decltype( r )>::type>::value
<< '\n';
g( r );
return 0;
}
Выходные данные программы:
The size of the referenced array is 8
Anthony
Размер строкового литерала (массива, в котором хранится строковый литерал) равен 8
потому что строка содержит также завершающий нулевой символ '\0'
.
В демонстрационной программе выражение
std::extent<std::remove_reference<decltype( r )>::type>::value
может быть заменено только выражением
sizeof( r )