您好,欢迎访问一九零五行业门户网

从cocos2dx中寻找函数指针传递的方法

目的 看到群里有个朋友搞了好几天函数指针传递,没搞好。所以写一篇文章,旨在从cocos2dx中帮朋友们找到如何传递指针。 旧版本的函数指针传递 全局函数函数指针调用 一般在c11之前,我们一般是这样定义一个函数指针类型。 typede void(*pfunc)(int,...); 什
目的看到群里有个朋友搞了好几天函数指针传递,没搞好。所以写一篇文章,旨在从cocos2dx中帮朋友们找到如何传递指针。
旧版本的函数指针传递全局函数函数指针调用一般在c++11之前,我们一般是这样定义一个函数指针类型。
typede void(*pfunc)(int,...);
什么意思呢?
typedef void/*return type of function*/
(*pfunc/*the pointer of function*/)
(int,.../*the types of function parameters*/);typedef void/*函数返回类型*/(*pfunc/*函数指针*/)(int,.../*函数参数类型*/);
ok,那么好了,该如何调用呢?
一般来说是像下面这样的。
typedef void(*pfunc)();void fa(){ };void fb(pfunc pf){ (*pf)(/*里面加函数参数*/) };void fc(){ fb(&fa);};
即为在fc中调用fb,fb的参数为fa指针。
成员函数函数指针的调用那么成员函数如何调用呢?
只需要加一个类名修饰符即可。
示例如下:
class c;typedef void(c::*pfunc)();void c::fa(){};void c::fb(pfunc pf){ (this->*pf)()};void c::fc(){this->fb(&c::fa);};
其实,有心的朋友应该会注意到cocos2dx 版本中的各种selector即为宏定义的函数指针的引用,定义如下:
typedef void (ref::*sel_callfunc)();typedef void (ref::*sel_callfuncn)(node*);typedef void (ref::*sel_callfuncnd)(node*, void*);typedef void (ref::*sel_callfunco)(ref*);typedef void (ref::*sel_menuhandler)(ref*);typedef void (ref::*sel_schedule)(float);#define callfunc_selector(_selector) static_cast(&_selector)#define callfuncn_selector(_selector) static_cast(&_selector)#define callfuncnd_selector(_selector) static_cast(&_selector)#define callfunco_selector(_selector) static_cast(&_selector)#define menu_selector(_selector) static_cast(&_selector)#define schedule_selector(_selector) static_cast(&_selector)
所以不懂函数指针的朋友完全可以模仿它。 相信你很快就能上手。
c++11 中std::function的应用cocos2dx 里面std::function定义的各种回调的解析假设我们不知道std::function如何使用,那么只有浏览cocos2dx3.x里面的源码,我们会发现有大量的callback 是用std::function定义的。
我们在此,首先用cocos2dx里面的网络http请求的返回函数举例。
httprequest 的回调定义为   
  inline void setresponsecallback(const cchttprequestcallback& callback)
    {
        _pcallback = callback;
    }
追踪cchttprequestcallback,可以发现cchttprequestcallback即为std::function定义的: 
typedef std::function cchttprequestcallback;
使用过的同学应该知道怎么调用的,
一般都是 setresponsecallback(cc_callback_2(classname::jsonrequestcompleted,this));
cc_callback是什么东东,其实就是std::bind的引用宏定义。我们查看定义如下:
#define cc_callback_0(__selector__,__target__, ...) std::bind(&__selector__,__target__, ##__va_args__)#define cc_callback_1(__selector__,__target__, ...) std::bind(&__selector__,__target__, std::placeholders::_1, ##__va_args__)#define cc_callback_2(__selector__,__target__, ...) std::bind(&__selector__,__target__, std::placeholders::_1, std::placeholders::_2, ##__va_args__)#define cc_callback_3(__selector__,__target__, ...) std::bind(&__selector__,__target__, std::placeholders::_1, std::placeholders::_2, std::placeholders::_3, ##__va_args__)
很明显,cc_callback_2就是 std::bind里面传参数,第一个是引用参数表示函数,第二个是目标,第三个,第四个是占位符,后面是不定参数。
所以可以等价代换为std::bind,那么我们上面的回调可以变成
setresponsecallback(std::bind(&classname::jsonrequestcompleted,this,std::placeholders::_1,std::placeholders::_2));
自定义std::function的应用通过以上分析,相信大家已经掌握了如何通过std::function传递函数,以及std::bind去调用。不过为了照顾一些基础薄弱的朋友,我还是给出一个简单的例子。
class c;void c::fa(){}void c::fb(const std::function &func){ if (func) { func(); }}void c::fc(){ fb(std::bind(&c::fa,this));}
关于非成员函数使用std::function非成员函数使用std::function和上面的函数指针实际上是一致的,鉴于它比较容易,就不在此赘述了,还不会的朋友可以试一下。

申明:http://blog.csdn.net/q229827701/article/details/41479753


其它类似信息

推荐信息