C++中施用模板传递函数类型

C++中使用模板传递函数类型

首先看了常用的写法:

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,即无法创建它的实例、无法对它的实例初始化或赋值。只能对它的指针进行初始化和赋值然后使用。