|
"C with Classes"
|
||||||
template <typename T> Max(T a, T b)23.03.2021, 22:16. Показов 3676. Ответов 18
Метки нет (Все метки)
Заметим, что шаблон max() внутренне возвращает b < а ? а : b, а не a < b ? b : а, чтобы гарантировать, что функция корректно ведет себя, даже когда два значе ния эквивалентны, но не равны. Почему важен именно данный порядок b < а ? а : b а не a < b ? b : а?Добавлено через 6 минут Почему при a == b важно вернуть именно b?Добавлено через 15 минут оригинал из книги "C++ Templates The Complete Guide Second Edition" Note that the max() template according to [StepanovNotes] intentionally returns “b < a ? a : b” instead of “a < b ? b : a” to ensure that the function behaves correctly even if the two values are equivalent but not equal.
1
|
||||||
| 23.03.2021, 22:16 | |
|
Ответы с готовыми решениями:
18
Template<typename T> vs auto
|
|
Вездепух
13202 / 6837 / 1822
Регистрация: 18.10.2014
Сообщений: 17,294
|
||||||||||||
| 23.03.2021, 22:28 | ||||||||||||
Сообщение было отмечено _stanislav как решение
РешениеЭто цитата сноски из книги "Шаблоны. Справочник разработчика". Цитата целиком содержит ссылку [64] на http://stepanovpapers.com/notes.pdf. Вот там на страницах 61-62 и объясняется, о чем идет речь. Степанов сначала пишет о реализации функции sort_2. Пусть мы реализовали ее так
sort_2 было синхронизировано с поведением min и max. То есть если мы выполнили sort_2(a, b), то после этого min(a, b) должно возвращать именно a, а max(a, b) должно возвращать именно b.Вот именно в таком контексте выбор b для возвращения из max имеет смысл.
1
|
||||||||||||
|
"C with Classes"
|
|||
| 24.03.2021, 06:29 [ТС] | |||
|
Добавлено через 40 минут
min и max как бы оставляли объекты на месте в отсортированном порядке если объекты равны?эквивалентны, но не равны?
0
|
|||
|
Вездепух
13202 / 6837 / 1822
Регистрация: 18.10.2014
Сообщений: 17,294
|
||
| 24.03.2021, 06:51 | ||
|
0
|
||
|
"C with Classes"
|
|
| 24.03.2021, 18:41 [ТС] | |
|
0
|
|
|
Вездепух
13202 / 6837 / 1822
Регистрация: 18.10.2014
Сообщений: 17,294
|
|||||||
| 24.03.2021, 19:13 | |||||||
|
В смысле, что они отличимы друг от друга. Вот предикат
0
|
|||||||
|
"C with Classes"
|
|
| 24.03.2021, 19:24 [ТС] | |
|
0
|
|
|
Вездепух
13202 / 6837 / 1822
Регистрация: 18.10.2014
Сообщений: 17,294
|
||
| 24.03.2021, 19:32 | ||
|
Предикат "less" определяет обобщенное соотношение "меньше", из которого выводится обобщенное соотношение "эквивалентность". А уж называть ли для краткости эквивалентность "равенством" - это уже вам решать. Помня при этом, что речь идет все таки об эквивалентности.
0
|
||
|
"C with Classes"
|
|
| 24.03.2021, 19:41 [ТС] | |
|
TheCalligrapher, а если исправить эту цитату так:
..., что функция корректно ведет себя, даже когда два значе ния эквивалентны, и равны. то реализация может быть любой в смысле порядка a и b?, например a < b ? b : а, потому что по сути равенство это строгая эквивалентность?
0
|
|
|
зомбяк
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
|
|
| 24.03.2021, 19:51 | |
Сообщение было отмечено _stanislav как решение
Решение
_stanislav, в смысле что операторы "больше" и "меньше" могут быть переопределены таким образом, что для большого множества возможных экземпляров класса они одновременно не выполняются. При этом данные экземпляры могут быть не равными (опять же относительно переопределённого оператора "равно") или отличаться по набору байтов (отличие по memcmp() ).
Добавлено через 4 минуты А смысл всего написанного - чтобы max() в случае, если переопределённый оператор "<" не различает a и b, выбирал именно a (что полезно, если там далее будет оператор перемещения или ещё что-то).
0
|
|
|
"C with Classes"
|
|
| 24.03.2021, 19:52 [ТС] | |
|
TRam_, да вроде бы допер, спасибо.
0
|
|
|
зомбяк
1585 / 1219 / 345
Регистрация: 14.05.2017
Сообщений: 3,940
|
|
| 24.03.2021, 19:54 | |
|
Т.к. b интуитивно воспринимается как второй, дополнительный аргумент к этой функции.
0
|
|
|
"C with Classes"
|
|
| 24.03.2021, 19:55 [ТС] | |
|
0
|
|
|
Комп_Оратор)
|
||||||
| 24.03.2021, 20:12 | ||||||
Сообщение было отмечено _stanislav как решение
Решение
_stanislav, я попробую свой вариант объяснения. Представь, что операторы сравнения такого класса
Полная идентичность и эквивалентность могут совпадать если способ сравнения опирается на сравнение всех подэлементов (мой самопал). Проще говоря, при сравнении по окрасу, все розовые слоны эквивалентны. Независимо от толщины хоботов.
0
|
||||||
|
"C with Classes"
|
|
| 24.03.2021, 20:17 [ТС] | |
|
0
|
|
|
Вездепух
13202 / 6837 / 1822
Регистрация: 18.10.2014
Сообщений: 17,294
|
||
| 24.03.2021, 20:46 | ||
![]() Cмысл всего написанного - чтобы max() выбирал именно b. А min() выбирал именно a.
0
|
||
|
Комп_Оратор)
|
||||||
| 24.03.2021, 21:39 | ||||||
|
_stanislav, вообще, пример с
0
|
||||||
|
Вездепух
13202 / 6837 / 1822
Регистрация: 18.10.2014
Сообщений: 17,294
|
||
| 24.03.2021, 21:49 | ||
b, а не на a. В этом вся суть вопроса и ответа. Однако все эти соображения имеют смысл только в контексте синхронизации с вышеприведенной функцией sort_2 (и аналогичными функциями)
1
|
||
|
Комп_Оратор)
|
|||
| 24.03.2021, 21:57 | |||
|
Как в тернарнике зашит Этот незаметный шит. у max от _stanislav, аргументы следуют в порядке a,b и далее в тексте обсуждается:
0
|
|||
| 24.03.2021, 21:57 | |
|
Помогаю со студенческими работами здесь
19
Функция вычисления суммы элементов одномерного массива с помощью template<typename T> Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html
Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
|