В данный момент 0:43:15 в этом Tech-Talk о D, обсуждается реализация функции min. Озабоченность по поводу "стабильности" и "дополнительной перетасовки (если значения равны)", когда используется в некоторых алгоритмах (ах), предлагается в качестве одной из причин показанной реализации.
Может ли кто-либо предоставить реальный/практический вариант использования (или предоставить более подробное объяснение), где эта конкретная реализация min является "стабильной" (ака лучше), а не ее другой возможной реализацией? Или это просто еще один пример альфа-geeks, который слишком далеко?
Рекомендуемая реализация:
template <class LHS, class RHS, class Return>
inline Return min(LHS& lhs, RHS& rhs)
{
return (rhs < lhs) ? rhs : lhs;
}
Другая возможная реализация:
template <class LHS, class RHS, class Return>
inline Return min(LHS& lhs, RHS& rhs)
{
return (lhs < rhs) ? lhs: rhs;
}
Предложение N2199 предоставляет реализации, основанные на последних, обратите внимание, что предложение не было успешным в настоящее время.
Другие актуальные предложения, касающиеся min/max, N1840, N2485 и N2551