|
Неэпический
|
|||||||||||
Применение is_same для списка типов01.02.2016, 03:16. Показов 4735. Ответов 17
Метки нет (Все метки)
Итак, std::is_same может сравнить только два типа.
Написал велосипед, который сравнивает первый тип со всеми остальными. Собственно, вот код:
is_one_same - определяет, есть ли в списке параметров хоть один тип, одинаковый с первым в списке, т.е. false, если все типы отличны от первого, true - во всех остальных случаях. is_all_same - определяет, все ли типы в списке одинаковые,т.е. true, если все типы соответствуют первому, false - во всех остальных случаях. Пример использования:
Для чего это мне может пригодится, опишу в теме Обертка над boost::lexical_cast для работы с unsigned типами
0
|
|||||||||||
| 01.02.2016, 03:16 | |
|
Ответы с готовыми решениями:
17
Используя производные классы, определить класс параметризованного списка одного из следующих типов. Применить его для построения списка объектов указа Применение типов Применение RAW типов |
|
В астрале
8049 / 4806 / 655
Регистрация: 24.06.2010
Сообщений: 10,562
|
|
| 01.02.2016, 10:35 | |
|
Croessmah, В С++14 можно юзать std::logical_and/std::logical_or они constexpr cудя по документации.
Есть подозрение что можно реализовать is_same проще.
1
|
|
|
|
||
| 01.02.2016, 11:12 | ||
|
Глядя на код, складывается впечатление, что хотелось применить как можно больше всяких фич (так бывает после прочтения новой книги ), из-за чего код получился неоправданно сложный. Не по теме: После того, как я научился применять SFINAE-фичи из С++11 я написал в рабочем проекте класс, в котором один и тот же метод реализован для разных типов при помощи enable_if, тогда мне показалось это круто. Уже позже глядя на это я понял, что это решается банальной перегрузкой, которая описана в начале любой книги по С++ для начинающих. Не надо доводить себя до такого, это плохо :) Если есть простое простое решение - нужно использовать простое решение.
0
|
||
|
Неэпический
|
||||||||
| 01.02.2016, 12:35 [ТС] | ||||||||
![]() Добавлено через 27 минут Переделал так:
видать спал больше ![]() Добавлено через 8 минут В gcc 4.9.3 с ключем -std=c++14 всё равно std::logical_and/std::logical_or без constexpr ![]() Печалька.
0
|
||||||||
|
Игогошка!
1801 / 708 / 44
Регистрация: 19.08.2012
Сообщений: 1,367
|
||||||
| 01.02.2016, 14:09 | ||||||
|
Croessmah, я мельком глянул, наверное что-то упустил, но почему так не катит?
4
|
||||||
|
Неэпический
|
||
| 01.02.2016, 14:23 [ТС] | ||
|
Но это я что-то упустил, а не Вы. Добавлено через 3 минуты
0
|
||
|
|
|||
| 01.02.2016, 14:50 | |||
|
Добавлено через 13 секунд
0
|
|||
|
Неэпический
|
||||||
| 01.02.2016, 15:20 [ТС] | ||||||
|
Добавлено через 9 минут Во, понял что я упустил.
0
|
||||||
|
19491 / 10097 / 2460
Регистрация: 30.01.2014
Сообщений: 17,805
|
||||||
| 02.02.2016, 13:07 | ||||||
Сообщение было отмечено Новичок как решение
Решение
ct0r, Croessmah, Можно проще и без рекурсии:
13
|
||||||
|
Игогошка!
1801 / 708 / 44
Регистрация: 19.08.2012
Сообщений: 1,367
|
|
| 02.02.2016, 13:30 | |
|
DrOffset, я бы так скорее всего не писал, но прием забавный однако
0
|
|
| 02.02.2016, 13:59 | |
|
0
|
|
| 02.02.2016, 14:13 | |
|
0
|
|
|
|
||||||
| 02.02.2016, 15:18 | ||||||
|
Блин, не могу идею дожевать, просто рабочее время трачу, пора завязывать, работать надо. Если кто-то доведет до ума, буду признателен. Либо я завтра наверное выделю на это время, доделаю.
0
|
||||||
|
279 / 39 / 13
Регистрация: 11.10.2015
Сообщений: 405
|
|
| 14.04.2017, 17:41 | |
|
DrOffset, я не очень понимаю для чего тут параметры шаблона меняются наизнанку...мудреный код у вас вышел
Добавлено через 54 секунды Kastaneda, мне кажется что тут через параметр пэк и рекурсию раскрывать нужно всю эту канитель
0
|
|
|
Любитель чаепитий
|
||
| 14.04.2017, 19:47 | ||
|
как будет работать: is_all_same<int, int, int> == std::is_same<pack<int, int, int>, pack<int, int, int>>;is_all_same<int, int&, int> == std::is_same<pack<int, int&, int>, pack<int&, int, int>>;как видишь, во втором случае типы не совпадают.
1
|
||
| 14.04.2017, 19:47 | |
|
Помогаю со студенческими работами здесь
18
Применение параметризированных типов Применение обнуляемых типов в C# Применение null-совместимых типов, проверка корня Применение в программах однозвсвязного списка
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
|
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net
REST сервисы временно не работают, только через Web.
Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
|
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи
и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|