测试AssetsManager,发现create里需要传入3个回调,自己尝试多次都是编译失败,于是查了点资料,记录下,备查。
需要传回调函数,直接使用宏里的CC_CALLBACK_X系列函数即可,后面的X代表回调需要传递的参数个数。
在cocos\base\ccMacros.h里可以看到宏定义的具体内容:
// new callbacks based on C++11 #define CC_CALLBACK_0(__selector__,__target__,...) std::bind(&__selector__,##__VA_ARGS__) #define CC_CALLBACK_1(__selector__,std::placeholders::_1,##__VA_ARGS__) #define CC_CALLBACK_2(__selector__,std::placeholders::_2,##__VA_ARGS__) #define CC_CALLBACK_3(__selector__,std::placeholders::_3,##__VA_ARGS__)
看上去是C++11的新特性。
简单解释一下就是:
- bind预先绑定的参数需要传具体的变量或值进去,对于预先绑定的参数,是pass-by-value的
- 对于不事先绑定的参数,需要传std::placeholders进去,从_1开始,依次递增。placeholder是pass-by-reference的
- bind的返回值是可调用实体,可以直接赋给std::function对象
- 对于绑定的指针、引用类型的参数,使用者需要保证在可调用实体调用之前,这些参数是可用的
- 类的this可以通过对象或者指针来绑定
一个栗子:
CC_CALLBACK_1(HelloWorld::f1,this) void HelloWorld::f1(int nCode)
上面,先看f1函数,有一个参数,是不能事先绑定的参数,所以使用CC_CALLBACK_1,this是预先绑定的参数,后面还可以加上其他可预先绑定的参数,比如这样:
CC_CALLBACK_1(HelloWorld::f1,this,nNum,nId)上面的nNum和nId都是可预先绑定的,就是每次调用f1的时候,this、nNum和nId的值都是一样的。
std::placeholders::_1就对应nCode这个不可预先绑定的参数,也就是f1的参数,每次都可能是不一样的。