C++中施用模板传递函数类型
C++中使用模板传递函数类型
是的,你可能就此以为函数指针在调用的时候,是否解引用都无所谓了吧?我跟你想得一样,是的,这是对的,但是注意我前面的用词“函数指针在调用的时候,是否解引用都无所谓”,那么还可能在什么情况下使用函数指针呢?没错,就是“使用模板传递函数类型”的时候!
int(char)是使用模板传递函数类型,c(fi)给C的构造函数传递函数指针fi,对fi的调用,可以使用_t('a')和(*_t)('a')两种方式(当然,你也可以在main函数中使用fi('a')和(*fi)('a')调用函数fi),但是对于int(char)类型的变量t2,却无法复制构造,只能使用指针赋值方式。
首先看了常用的写法:
int fi(char){ return 1; } int main(){ int (*pf)(char)=fi; //以下两种函数调用方式,没有区别 pf('a');//ok (*pf)('a');//ok return 0; }
是的,你可能就此以为函数指针在调用的时候,是否解引用都无所谓了吧?我跟你想得一样,是的,这是对的,但是注意我前面的用词“函数指针在调用的时候,是否解引用都无所谓”,那么还可能在什么情况下使用函数指针呢?没错,就是“使用模板传递函数类型”的时候!
来看下面一个例子:
template<typename T> class C{ public: C(T _t){ _t('a');//ok (*_t)('a');//ok T *t1=_t;//ok t1=_t; //(*t1)=_t;//compile error!assignment of read-only location //T t2=_t;//compile error!variable 't2' has function type } }; int fi(char){ return 1; } int main(){ C<int(char)> c(fi);//使用模板传递函数类型 return 0; }
int(char)是使用模板传递函数类型,c(fi)给C的构造函数传递函数指针fi,对fi的调用,可以使用_t('a')和(*_t)('a')两种方式(当然,你也可以在main函数中使用fi('a')和(*fi)('a')调用函数fi),但是对于int(char)类型的变量t2,却无法复制构造,只能使用指针赋值方式。
在对int(char)函数类型变量赋值时,它表现得像是一个函数常量(就像函数名f1一样),而如果对其指针的引用赋值时,它表现得像typedef int(*const constPF)(char)一样。所以,它更像是一个“constructor、copy constructor和operator=”都为private的class,即无法创建它的实例、无法对它的实例初始化或赋值。只能对它的指针进行初始化和赋值然后使用。