Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.93/29: Рейтинг темы: голосов - 29, средняя оценка - 4.93
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886

Шаблоны. Плохо понимаемые моменты из книги "Шаблоны С++. Справочник разработчика". (Вандевурд, Джосаттис)

07.10.2015, 15:04. Показов 6282. Ответов 32
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Так как изучаю эту книгу, то в некоторых местах возникают вопросы. Чтобы не плодить много тем, корни у которых одни, решил создать эту тему.

Дошел до места. Параметры шаблонов функций, не являющиеся типами.
Там описан такого вида пример
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>
#include <vector>
#include <algorithm>
 
template <typename T, int VAL>
T addValue(T const& x){
   return x+VAL;
}
 
int main()
{
     vector<int> v1(100);
     vector<int> v2(100);
     transform(v1.begin(), v1.end(),v2.begin(),addValue<int,5>);
}
Дальше авторы уточняют о проблеме, которая проявляется в этом примере.
Заметим, что в этом примере проявляется следующая проблема: addValue<int, 5> — это шаблон функции, который интерпретируется как имя семейства перегруженных функций (даже если это семейство состоит всего из одного элемента).
Я вообще авторов не понял. Просьба прояснить этот туманный момент.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.10.2015, 15:04
Ответы с готовыми решениями:

Использование обобщенных лямбда-выражений с SFINAE из книги "Шаблоны C++. Справочник разработчика"
(перевод)...

Шаблоны C++: справочник разработчика
Нашёл книжку в интернете. Прочитал несколько глав в электронном виде. И теперь хочу купить себе чтобы везде можно смотреть. Спасибо за...

Хранить шаблоны документов в базе и выводить данные в эти шаблоны
Доброго времени суток. Интересует вопрос: мне необходимо формировать вордовские документы по шаблону. У меня создан шаблон документа...

32
 Аватар для ture
553 / 361 / 206
Регистрация: 27.11.2014
Сообщений: 1,049
07.10.2015, 15:17
daslex, шаблон - это просто заготовка. шаблона не переживет компиляцию. на основе шаблона компилятор (вместо тебя) напишет конечную функцию с вполне конкретными типами. ты делаешь шаблон, что не писать сто раз одну и ту же функцию меня тип параметра.

Добавлено через 1 минуту
правда после этого набора слов препод у меня на уроке махнул рукой и отпустил всех пораньше.
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
07.10.2015, 15:18  [ТС]
Это не пояснение цитаты. Я знаю, что такое шаблон. Вопрос не в том, что он такое. Откуда тут интерпретация как семейства перегруженных функций.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
07.10.2015, 15:20
А то, что он дальше пишет, почему не привёл? Там же объясняется причина.
0
 Аватар для ture
553 / 361 / 206
Регистрация: 27.11.2014
Сообщений: 1,049
07.10.2015, 15:21
Ну это автор конечно завернул. Перегруженные они лишь пока не компилировалось. А потом все разные станут (трансляция имен с параметрами какая-то).
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
07.10.2015, 15:28
Там сказано:
However, according to the current standard, sets of overloaded functions cannot be used for template parameter deduction. Thus, you have to cast to the exact type of the function template argument:

C++
1
2
3
std::transform (source.begin(), source.end(),  // start and end of source 
                dest.begin(),                  // start of destination 
                (int(*)(int const&)) addValue<int,5>);  // operation
There is a proposal for the standard to fix this behavior so that the cast isn't necessary in this context (see [CoreIssue115] for details), but until then the cast may be necessary to be portable.

Книжка 2002 года, может это уже не актуально.
1
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
07.10.2015, 15:29  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
А то, что он дальше пишет, почему не привёл? Там же объясняется причина.
нет. там пишет про то, что "не по фэншую" и "как по фэншую".
В той книге, что у меня перед глазами причина не объясняется.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
07.10.2015, 15:32
Я же привёл текст. Он говорит, что according to the current standard надо делать так-то. Но есть предложение стандарт подправить. Книжка древняя, может в C++11 уже не так. Пусть спецы прокомментируют.
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
07.10.2015, 15:36  [ТС]
Понимание первопричины гораздо важнее понимания отдельного кусочка. Да, он говорит как надо делать. Но тут я могу сделать, а где-то могу не сделать, ибо не вижу где и когда получится семейство перегруженных функций, а где семейства перегруженных функций не получится.
Я например, могу так понять, что если в параметрах шаблона функции есть хотя бы 1 не тип, то нужно явное приведение при обращении к такой функции. Но это может оказаться неправильным выводом, я просто конкретики не вижу. А полагаться на свои незнания как на знания нехорошо.
0
 Аватар для ture
553 / 361 / 206
Регистрация: 27.11.2014
Сообщений: 1,049
07.10.2015, 15:42
C++
1
addValue<int, 5>
Это явное требование создать функцию для int и тут вызвать именно ее.

Добавлено через 6 минут
C++
1
int VAL
По моим понятиям транслируется в еще один параметр.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
07.10.2015, 15:46
Лучший ответ Сообщение было отмечено daslex как решение

Решение

Цитата Сообщение от daslex Посмотреть сообщение
если в параметрах шаблона функции есть хотя бы 1 не тип, то нужно явное приведение при обращении к такой функции
Я из текста понял, что дело не в том, что там "не тип", а в самой записи. Она интерпретируется как шаблон.
1
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
07.10.2015, 15:50  [ТС]
Да. Интерпретируется как шаблон. А все. Понял
Там раньше написано
шаблон функции представляет семейство функций.
.

Не по теме:

Поназаводили синонимов, блин

. Вопрос отпал.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
07.10.2015, 15:52
daslex, так в твоей книги есть перевод этого куска или нет?
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
07.10.2015, 16:00  [ТС]
Да. у меня русский вариант книги. Просто это за 30 страниц до написано.

Добавлено через 6 минут
(int(*)(int const&))addValue<int,5>);
Цитата Сообщение от nmcf Посмотреть сообщение
Книжка 2002 года, может это уже не актуально.
мне это тоже интересно узнать. актуально или же нет.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
07.10.2015, 16:57
Что-то спецы пропали все.
0
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,816
07.10.2015, 20:25
daslex,
Вот эта надпись
Заметим, что в этом примере проявляется следующая проблема: addValue<int, 5> — это шаблон функции, который интерпретируется как имя семейства перегруженных функций (даже если это семейство состоит всего из одного элемента).
означает, что функция не интерпретируется однозначно, так, как будто бы речь идет о семействе перегруженных функций.
Семейство перегруженных функций - это когда вот так:
C++
1
2
int addValue(int a);
double addValue(double a);
Демо

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <vector>
#include <algorithm>
 
int addValue(int a);
double addValue(double a);
 
int main()
{
    std::vector<int> v1(100);
    std::vector<int> v2(100);
    std::transform(v1.begin(), v1.end(),v2.begin(),addValue);
}
http://rextester.com/QRA5825

В тот момент, когда мы попытаемся такую функцию передать в тот же std::transform, возникнет неоднозначность.
Так вот, Йосуттис и еще несколько человек в 1999 году нашли баг в формулировке стандарта. Вследствие этого бага, стандарт обозначал такое же поведение для шаблонной функции, не смотря на полную конкретизацию типов аргументов шаблона, он ее считал неоднозначной и компилятор, строго следовавший стандарту, выдавал ошибку. Лечилось это приведением типа (как сейчас лечится вариант с перегрузкой).

В книге есть сноска на обсуждение этого бага.
Issue 115.
Другое, на эту же тему: Issue 250.
Естественно, далеко не все компиляторы реализовали у себя это ошибочное требование, поэтому даже в то время подобная проблема проявлялась далеко не везде. Но я отлично помню эту проблему на GCC 2.x.
8
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
07.10.2015, 20:43  [ТС]
Насчет демо я понимаю и понял бы. Просто туманностей нагоняет такой момент, что в случае, описываемом в книге, у шаблона указано 2 параметра, тип которых известен. В демо же вариант более очевиден и просто показана неоднозначность непосредственно при самой перегрузке.
Я вообще сейчас так воспринимаю, что у transform возвращается значение, вот тип этого возвращаемого значения не может быть выведен шаблоном, потому что вызов функции по синтаксису как синтаксис имени, а не как синтаксис вызова.

Вот такой туман у меня в голове.
0
19500 / 10105 / 2461
Регистрация: 30.01.2014
Сообщений: 17,816
07.10.2015, 20:59
Лучший ответ Сообщение было отмечено daslex как решение

Решение

Цитата Сообщение от daslex Посмотреть сообщение
Я вообще сейчас так воспринимаю, что у transform возвращается значение, вот тип этого возвращаемого значения не может быть выведен шаблоном, потому что вызов функции по синтаксису как синтаксис имени, а не как синтаксис вызова.
Ничего не понял.
Суть в том, что transform (transform - шаблонная функция) принимает предикат, тип которого выводится из переданного параметра. Но предикат нельзя вывести однозначно, потому что вариантов больше, чем один. Такая же ситуация возникает, если мы подставим неполностью специфицированный шаблон, т.к. он воспримется как семейство функций.
C++
1
2
3
4
5
6
7
8
9
10
11
12
template <typename T, int V>
T addValue(int a)
{
    return a + V;
}
 
int main()
{
    std::vector<int> v1(100);
    std::vector<int> v2(100);
    std::transform(v1.begin(), v1.end(),v2.begin(), addValue<int>);
}
А вот баг заключался в том, что даже полностью специфицированный шаблон все равно воспринимался подобным образом.
В общем, это давно уже неактуально.

Добавлено через 10 минут
daslex, просто хочу добавить, что это неактуально как минимум с С++03 (редакция стандарта 2003 года).
3
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
10.10.2015, 21:36  [ТС]
После оговоренной темы, идет следующая. (5.3 Шаблоны членов классов). Вроде бы понятна, но есть кое что, чего я не осознаю. Пример комментировать не буду. Он не из книги, он - моя попытка реализации того, что пытаются донести в книге.

Я застрял на возвращаемом значении.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#include <iostream>
 
using namespace std;
 
template <typename T>
class MyClass{
    T value;
public:
    T get_value();
    void set_value(const T &x);
    MyClass(const T &x):value(x) {}
 
    template <typename T2>
    T& operator = (T2 &) ;
};
 
template <typename T>
 T MyClass<T>::get_value(){
    return (*this).value;
}
 
template <typename T>
void MyClass<T>::set_value(const T &x)  {
    value = x;
}
 
template <typename T>
   template <typename T2>
T& MyClass<T>::operator = (T2 &temp_class) {
    MyClass<T>::value = temp_class.get_value();  //Через геттер и сеттер у меня не получается
    return *this;   /* <----- Вот здесь застрял. */
}
 
 
int main(){
    MyClass<int>    Num1(20);
    MyClass<double> Num3(3.14);
   Num3 = Num1; 
}
Увы, но я, действительно не понимаю, чего от меня ждет компилятор.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
10.10.2015, 21:45
А почему возвращается T, а не MyClass?
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.10.2015, 21:45
Помогаю со студенческими работами здесь

Чем отличаются шаблоны HTML и шаблоны WordPress
В чём различие между шаблонами HTML и WordPress. Кроме того, что создаются они разными способами. Конкретно имею в виду, почему их...

«Шаблоны шаблонов» vs «шаблоны с параметрами-шаблонами».
«Шаблоны шаблонов» vs «шаблоны с параметрами-шаблонами». Есть ли разница в этих понятиях? Если есть, то в чём? И где (в каких...

Помогите писать на С++ через шаблоны. Консуле я писал, но надо писать исползуя шаблоны
В одномерном массиве, состоящем из п вещественных элементов, вычислить: 1) количество элементов массива, равных 0; 2) сумму элементов...

Не могу обнаружить ошибку в учебной программе из книги (шаблоны классов)
Вот упрощённый код учебной программы из книжки Детейла. Не компилится, пишет: /123/main.cpp|21|error: request for member ‘print’ in ‘l’,...

Шаблоны
Я разбираюсь с ООП в С++ и застрял на шаблонах, будьте добры приведите пример кода, к примеру там.... вес машины и шаблон,(ну вообщем на...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru