compare(const char (&p1)[N], const char (&p2)[M]) {
return strcmp(p1, p2);
compare("hi", "mom")
утверждается что компилятор создаст такой вызов:
int compare(const char (&p1)[3], const char (&p2)[4])
Каким образом он поймет что на место N нужно подставить размер массивов?
Потому что литералы это массивы?
так вопрос в другом
В том как темплейт определяет размер массив в компайл тайме? Или про вывод? Ну он сопоставляет типы и выводит шаблонные параметры если кратко, а больше не скажу
да, второе, как он знает что вместо N надо размер массива поставить
А что еще он может туда подставить?)
да что угодно
Например
А каким образом компилятор понимает, что на место T нужно подставить int? template<typename T> void foo(T&); // ... int x = 42; foo(x); А как он понимает, что тут нужно подставить массив? int arr[] = { 1, 2, 3 }; foo(arr); Если foo умеет целый массив выводить, то почему не может лишь часть его типа вывести?
Обсуждают сегодня