Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Eraston
59 / 11 / 3
Регистрация: 09.09.2014
Сообщений: 130
#1

Вызов функции-члена элементов списка

11.08.2015, 20:20. Просмотров 311. Ответов 9
Метки нет (Все метки)

Вот есть список, хранящий указатели (на экземпляры классов).
Можно ли в нем реализовать подобную функцию?, вызывая которую, мы будем заведомо знать, адреса экземпляров какого именно класса он содержит.
C++
1
2
3
4
5
6
7
void Execute( <?> function, ... ){
    ptr* srh = head;
    while( srh ){
        srh->function( ... );
        srh = srh->next;
    }
}
Или как-то иначе это реализовать?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
11.08.2015, 20:20
Ответы с готовыми решениями:

рекурсивный вызов функции-члена
как осуществить рекурсивный вызов функции члена?

Вызов функции члена в заданом диапазоне
Нужно описать класс, в котором значение функции будет вычисляться в заданном...

Вызов функции-члена через std::function
Суть в следующем Задача сделать обертку вызывающую функцию член класса с...

Вызов функции-члена класса по адресу в памяти
Всем хорошего дня :) Допустим, что где-то есть static функция, не...

Объявление класса, создание объекта и вызов функции-члена
Всем добрый день! Вот так я объявляю класс. typedef map&lt;string, double&gt;...

9
tnk500
114 / 118 / 42
Регистрация: 25.08.2012
Сообщений: 1,294
Завершенные тесты: 3
11.08.2015, 20:34 #2
Eraston, в списке можно хранить указатели на объекты "родственных" классов (т.е. имеющих общего предка), создавая список как раз с элементами-указателями этого предка (надеюсь, я не ошибаюсь). Если это так, при пролистывании списка проверяйте тип элемента на равенство с типами, имеющих эту функцию, через операцию typeid, ну о ней в Интернете найде информацию
1
Velesthau
524 / 426 / 159
Регистрация: 25.11.2014
Сообщений: 1,662
11.08.2015, 20:35 #3
Распиши изначальную задачу, которую ты хочешь решить, подробнее. Можешь почитать про RTTI. Но, думаю, что тебе можно обойтись без этого.
0
Eraston
59 / 11 / 3
Регистрация: 09.09.2014
Сообщений: 130
11.08.2015, 20:55  [ТС] #4
Цитата Сообщение от tnk500 Посмотреть сообщение
Eraston, в списке можно хранить указатели на объекты "родственных" классов (т.е. имеющих общего предка), создавая список как раз с элементами-указателями этого предка (надеюсь, я не ошибаюсь)
Цитата Сообщение от Velesthau Посмотреть сообщение
Распиши изначальную задачу, которую ты хочешь решить, подробнее.
Это всё хорошо, но суть: написать один класс List с одной функцией Execute, дающей возможность вызова любого метода экземпляра любого класса. Т.е. в List могут содержаться классы разных веток, разных уровней.
Цитата Сообщение от tnk500 Посмотреть сообщение
проверяйте тип элемента на равенство с типами, имеющих эту функцию, через операцию typeid
Перебор и сравнение всех возможных типов?
0
tnk500
114 / 118 / 42
Регистрация: 25.08.2012
Сообщений: 1,294
Завершенные тесты: 3
11.08.2015, 21:04 #5
Eraston, именно. Впрочем, стоит посмотреть в сторону указателей на функции-члены объекта класса. Но это потребует одинакового имени функции в элементах списка (если нужно функцию вызвать непременно из всех), а также совпадение изначального типа указателя на функцию с типом функции, которую нужно вызвать.
1
hoggy
Заблокирован
Эксперт С++
11.08.2015, 21:51 #6
Цитата Сообщение от Eraston Посмотреть сообщение
реализовать?
вы хотите что то вроде такого?

http://rextester.com/JHSY73012

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
#include <iostream>
#include <list>
 
struct base
{
 
    virtual void foo() = 0;
 
};
 
 
struct der: base
{
    virtual void foo()  { std::cout<< "der::foo\n"; }
};
 
struct baz: base
{
    virtual void foo()  { std::cout<< "baz::foo\n"; }
};
 
 
int main()
{
    std::cout << "Hello, world!\n";
    
    std::list<base*> mylist;
    
    mylist.emplace_back( new der );
    mylist.emplace_back( new baz );
    
    auto&& method = &base::foo;
    
    for(auto&& p: mylist)
        (p->*method)();
    
}
0
Eraston
59 / 11 / 3
Регистрация: 09.09.2014
Сообщений: 130
11.08.2015, 22:30  [ТС] #7
Попользовался гуглом.
Думаю, это вполне корректно будет?:
Код
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
class A{
public:
    virtual int f1( int k ){printf("%d: aprint:%d\n",k,a);return a;}
    void f2( int k ){printf("%d: avoid:%d\n",k,a);}
    int a;
};
class B: public A{
public:
    B( int a, int b ):b(b){A::a=a;}
    virtual int f1( int k ){printf("%d: bprint:%d %d\n",k,a,b);return a;}
    void f2( int k ){printf("%d: bvoid:%d %d\n",k,a,b);}
    int b;
};
class L{
public:
    L(){
        for(int i = 0; i < s; i++ ){
            p[i] = new B( rand() % 10, rand() % 10 );
        }
    }
    ~L(){
        for(int i = 0; i < s; i++ ){
            if( p[i] ) delete p[i];
        }
    }
    template <typename T, typename F> void exe( F f ){
        for(int i = 0; i < s; i++ ){
            // + добавить проверку типа и наличия функции
            if( p[i] ) ( ( (T*)p[i] )->*f )( i );
        }
    }
private:
    enum{s=3};
    int n = 0;
    A *p[s];
};
int _tmain(int argc, _TCHAR* argv[])
{
    srand(134);
    L base;
    base.exe<A>( &A::f1 );
    base.exe<B>( &B::f1 );
    base.exe<A>( &A::f2 );
    base.exe<B>( &B::f2 );
    getchar();
    return 0;
}
Вывод
0: bprint:4 6
1: bprint:7 3
2: bprint:1 2
0: bprint:4 6
1: bprint:7 3
2: bprint:1 2
0: avoid:4
1: avoid:7
2: avoid:1
0: bvoid:4 6
1: bvoid:7 3
2: bvoid:1 2


Добавлено через 2 минуты
hoggy, может, конечно, std весь там такой функциональный, но мне необходим полный доступ к классам и возможности их модифицирования.

Добавлено через 17 минут
Цитата Сообщение от hoggy Посмотреть сообщение
for(auto&& p: mylist)
* * * * (p->*method)();
Не говоря уже о том, что здесь, походу, элементы списка выходят за его пределы, чего категорически нельзя допускать.
0
hoggy
Заблокирован
Эксперт С++
11.08.2015, 22:52 #8
Цитата Сообщение от Eraston Посмотреть сообщение
может, конечно, std весь там такой функциональный, но мне необходим полный доступ к классам и возможности их модифицирования.
не понял, при чем тут std, и как это мешает получать нолный доступ к объектам классов.

Цитата Сообщение от Eraston Посмотреть сообщение
Не говоря уже о том, что здесь, походу, элементы списка выходят за его пределы, чего категорически нельзя допускать.
цикл вида:
C++
1
2
for(auto&& p: mylist)
    (p->*method)();
в принципе не допускает выход за пределы диапазона.
0
Eraston
59 / 11 / 3
Регистрация: 09.09.2014
Сообщений: 130
11.08.2015, 22:57  [ТС] #9
Цитата Сообщение от hoggy Посмотреть сообщение
в принципе не допускает выход за пределы диапазона.
Допускает доступ к *p.
Цитата Сообщение от hoggy Посмотреть сообщение
не понял, при чем тут std, и как это мешает получать нолный доступ к объектам классов.
Полный доступ к классу list
0
hoggy
Заблокирован
Эксперт С++
12.08.2015, 02:51 #10
Цитата Сообщение от Eraston Посмотреть сообщение
Допускает доступ к *p.
ну и?

Цитата Сообщение от Eraston Посмотреть сообщение
Полный доступ к классу list
лист полностью под вашем контролем

вы сказать то что хотели?
0
12.08.2015, 02:51
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.08.2015, 02:51

Как такое может быть? (вызов функции-члена без объекта)
собственно вопрос озвучен. #include &lt;iostream&gt; using namespace std; ...

Простое Наследование и ошибка "Недопустимый вызов нестатической функции-члена"
У меня есть два класса M и К (наследуется от М). В классе М есть три переменные...

Используя рекурсивный вызов функции вычислить сумму заданного числа элементов ряда
В программировании я просто дуб дубом, но нужно срочно сделать одну задачу в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru