Неэпический
|
|||||||||||
1 | |||||||||||
Применение is_same для списка типов01.02.2016, 03:16. Показов 3867. Ответов 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 | 2 |
Croessmah, В С++14 можно юзать std::logical_and/std::logical_or они constexpr cудя по документации.
Есть подозрение что можно реализовать is_same проще.
1
|
01.02.2016, 11:12 | 4 |
Поддерживаю.
Глядя на код, складывается впечатление, что хотелось применить как можно больше всяких фич (так бывает после прочтения новой книги), из-за чего код получился неоправданно сложный. Не по теме: После того, как я научился применять SFINAE-фичи из С++11 я написал в рабочем проекте класс, в котором один и тот же метод реализован для разных типов при помощи enable_if, тогда мне показалось это круто. Уже позже глядя на это я понял, что это решается банальной перегрузкой, которая описана в начале любой книги по С++ для начинающих. Не надо доводить себя до такого, это плохо :) Если есть простое простое решение - нужно использовать простое решение.
0
|
Неэпический
|
||||||
01.02.2016, 12:35 [ТС] | 5 | |||||
Как раз занимаюсь
Добавлено через 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 | 6 | |||||
Croessmah, я мельком глянул, наверное что-то упустил, но почему так не катит?
4
|
Неэпический
|
|
01.02.2016, 14:23 [ТС] | 7 |
Да я ночью что только не перепробовал - не канает.
Но это я что-то упустил, а не Вы. Добавлено через 3 минуты
0
|
01.02.2016, 14:50 | 9 |
не, не осталось бы, просто этот вариант раньше бы вызвался, чем вариант с одним <T>. Но вариант с одним <T> тоже рабочий, я просто прогнал.
Добавлено через 13 секунд ага
0
|
Неэпический
|
||||||
01.02.2016, 15:20 [ТС] | 10 | |||||
Добавлено через 9 минут Во, понял что я упустил.
0
|
18840 / 9839 / 2408
Регистрация: 30.01.2014
Сообщений: 17,280
|
||||||
02.02.2016, 13:07 | 11 | |||||
Сообщение было отмечено Новичок как решение
Решение
ct0r, Croessmah, Можно проще и без рекурсии:
13
|
Игогошка!
1801 / 708 / 44
Регистрация: 19.08.2012
Сообщений: 1,367
|
|
02.02.2016, 13:30 | 13 |
DrOffset, я бы так скорее всего не писал, но прием забавный однако
0
|
DrOffset
|
02.02.2016, 13:59
#14
|
0
|
ct0r
|
02.02.2016, 14:13
#15
|
0
|
02.02.2016, 15:18 | 16 | |||||
Блин, не могу идею дожевать, просто рабочее время трачу, пора завязывать, работать надо. Если кто-то доведет до ума, буду признателен. Либо я завтра наверное выделю на это время, доделаю.
0
|
279 / 39 / 13
Регистрация: 11.10.2015
Сообщений: 405
|
|
14.04.2017, 17:41 | 17 |
DrOffset, я не очень понимаю для чего тут параметры шаблона меняются наизнанку...мудреный код у вас вышел
Добавлено через 54 секунды Kastaneda, мне кажется что тут через параметр пэк и рекурсию раскрывать нужно всю эту канитель
0
|
Любитель чаепитий
|
|
14.04.2017, 19:47 | 18 |
ну смотри, каждый инстанс шаблона создаёт новый тип.
как будет работать: 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 | |
14.04.2017, 19:47 | |
Помогаю со студенческими работами здесь
18
Применение обнуляемых типов в C# Применение null-совместимых типов, проверка корня Применение в программах однозвсвязного списка Ввод данных из списка с применение формулы Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |