Как перевести::* operator и member_fn в данный код?

Насколько я знаю: void (A::*p)() = &A::test_func; Значит это p указатель на функцию-член void A::test_func(), а также std::mem_fn(...) может использоваться, чтобы обернуть указатель на функцию-член.

Но в следующем фрагменте кода я не смог перевести void (Handler::*)() а также Handler::*member_fn имею в виду.

class Handler;

std::pair<boost::shared_ptr<Handler>, void (Handler::*)()> cb = job_queue.sync_pop();

void (Handler::*member_fn)() = cb.second;
(cb.first.get()->*member_fn)();

2 ответа

Решение

Это означает именно то, что вы описали в первом абзаце:

// cb contains a shared pointer to an instance of Handler and a member function of Hander
std::pair<boost::shared_ptr<Handler>, void (Handler::*)()> cb = job_queue.sync_pop(); 

// assign the member function stored in cb.second to a local variable    
void (Handler::*member_fn)() = cb.second; 

(cb.first.get()->*member_fn)(); // call the function stored in member_fn on 
                                // the object held by cb.first

Если этого недостаточно, вы можете найти минимальный пример с использованием стандартных библиотечных классов ЗДЕСЬ, что делает то же самое

class Handler;

std::pair<                     // a pair consisting of first and second
   boost::shared_ptr<Handler>, // first  - a shared pointer to Handler object
   void (Handler::*)()>        // second - a pointer to the member function of Handler class
cb = job_queue.sync_pop();     // sync_pop() returns such pair, stores it in cb variable

// varaible "member_fn" stores pointer to a member function from the pair
void (Handler::*member_fn)() = cb.second; 

// cb.first.get()->  - dereference pointer to Handler object, say handlerObj
// *member_fn        - dereference the pointer to member function
// (cb.first.get()->.*member_fn())()  - invoke the function stored in member_fn variable
//                                      on handlerObj (just like handlerObj.member_fn();)
(cb.first.get()->*member_fn)();

Это было бы более читабельным:

auto pair = job_queue.sync_pop();
auto function = std::bind(pair.second, pair.first.get());
function();
Другие вопросы по тегам