Форум программистов, компьютерный форум CyberForum.ru

Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов) - C++

Восстановить пароль Регистрация
 
kravam
быдлокодер
 Аватар для kravam
1512 / 872 / 44
Регистрация: 04.06.2008
Сообщений: 5,271
20.12.2011, 12:07     Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов) #1
собсно
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
40
41
42
43
44
45
46
47
48
49
#include <windows.h>
#include <stdio.h>
#include <vector>
#include <list>
#include <algorithm>
#include <cxxabi.h>
using namespace std;
 
 
//Это шаблонная функция
template <class T>
void f () {
 T rez;
 
 //Положим что-нибудь в контейнер
 rez.push_back (1);
 rez.push_back (2);
 
 //Здесь я определяю узнаю имя контейнера, который у меня используется
 char* realname= abi::__cxa_demangle(typeid(rez).name(), 0, 0, NULL);
 *strpbrk(realname,"<")= 0; realname+= 5;
 
 //Вот тут это имя можно даже посмотреть
 printf ("realname==%s \n", realname);
 
 //А тут мы сортируем контейнер разными способами в зависимости от того
 // какой у контейнера тип
 if (!(strcmp (realname, "list")))  
  rez.sort();
 
 
 //Если у контейнера будет тип "list" то компилится, если только этот
 //блок заблокирован, непонятно почему, ведь он будет выполняться 
 //только в том, случае, если тип контейнера как раз не list!
 
 //else 
  //sort(rez.begin(), rez.end());
 
}
 
int main () {
 SetConsoleCP (1251);
 SetConsoleOutputCP (1251);
 
 f< list<int> > ();
 
 getchar ();
 return 0;
}
Сложность сопряжена с тем, напомню, что списки сортируются с помощью функции-метода sort, в отличие от векторов или двусторонних очередей.
Спасибо, кто откликнется
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.12.2011, 12:07     Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов)
Посмотрите здесь:

C++ Динамический массив в С++: как поменять длину массива по ходу выполнения программы?
C++ Время выполнения программы увеличивается, если добавить проверку
C++ Как вы шаблонном классе определить контейнер, тип которого совпадает с именем параметра шаблона?
системная ошибка в ходе выполнения программы (наверно несоответствие типов) C++
C++ Безопасно ли использовать memcpy при выделении памяти по ходу выполнения програмы
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Андрей2011
29 / 23 / 2
Регистрация: 18.01.2011
Сообщений: 359
20.12.2011, 12:28     Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов) #2
нет ну как...если типы по умолчанию известны...строки там цифры еще что...то можно ведь перегружать ф-и например с помощью operator - подставлять под нужный тип.
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
20.12.2011, 12:30     Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов) #3
kravam, Можно написать функцию, которая в зависимости от переданного типа будет сортировать.
Т.е.

C++
1
2
3
4
5
6
7
8
9
10
11
template<class Container>
void sort(Container& cont)
{
    std::sort(cont.begin(), cont.end());
}
 
template<class T>
void sort(std::list<T>& lst)
{
    lst.sort();
}
kravam
быдлокодер
 Аватар для kravam
1512 / 872 / 44
Регистрация: 04.06.2008
Сообщений: 5,271
20.12.2011, 13:07  [ТС]     Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов) #4
ForEveR,а тогда возникает два вопроса, вот твой код:
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
#include <windows.h>
#include <stdio.h>
#include <vector>
#include <list>
#include <algorithm>
#include <cxxabi.h>
using namespace std;
 
 
template<class Container>
void sort_(Container& cont)
{
    std::sort(cont.begin(), cont.end());
}
 
 
template<class t>
void sort_(std::list<t>& lst)
{
    printf ("ddddddddddd\n");
    lst.sort();
}
 
 
 
int main () {
 SetConsoleCP (1251);
 SetConsoleOutputCP (1251);
 
 list <int> rez;
 rez.push_back (1);
 rez.push_back (2);
 
 sort_ (rez); 
 
 getchar ();
 return 0;
}
Почему компилятор подстьавляет именно нужную функцию, вторую то есть? Да, согласен, тип передаваемого параметра list <int> , а тип этой функции std::list<t> и они красиво друг другу подходят. Но у первой функции её параметр Container тоже запросто может быть типом list <int>! Тем не мене компилятор не путается, а подставляет именно вторую функцию, почему так?
ForEveR
Модератор
Эксперт C++
 Аватар для ForEveR
7927 / 4709 / 318
Регистрация: 24.06.2010
Сообщений: 10,524
Завершенные тесты: 3
20.12.2011, 13:23     Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов) #5
kravam, Читай про специализацию шаблонов. Выбирается та функция, которая наиболее подходит.
Yandex
Объявления
20.12.2011, 13:23     Как отсортирвоать контейнер, если его тип определяется по ходу выполнения программы? (динамическая идентификация типов)
Ответ Создать тему
Опции темы

Текущее время: 12:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru