函数声明中的指针

**用typedef定义函数指针类型**//定义函数指针类型cmpFuntypedefint(*cmpFun)(constint&,constint&);(3)这样,cmpFun就成了一种数据类型,可以用它来声明和定义形如(1)式中的pf那样的函数指针,比如:cmpFunpf=0;cmpFunpf=someFunction;举个例子来说明一下:includeincludeusingnamespacestd;//定义函数指针pfint(*pf)(constint&,constint&);//定义函数指针类型cmpFuntypedefint(*cmpFun)(constint&,constint&);//具体函数intintCompare(constint&aInt,constint&bInt)调用代码示例://函数指针作为返回值,retFunPointer返回一个cmpFun类型的函数指针cmpFunpf3=retFunPointer(aaInt);intresult=pf3(aaInt,bbInt);cout<

int*GetDate(intwk,intdy);main()先用字符型指针数组Names的地址来初始化指针nm。

通过函数指针调用函数函数指针是通过函数名及有关参数进行调用的。

从宏观来看,函数指针让我们调用函数时也能够直接从内存地址调用了,这充分说明了c语言的自由性,我们可以用它写出十分精简的程序,但是这样也容易造成使用出错,我们在使用时要小心。

顾名思义,指针函数即返回指针的函数。

pam是函数,所以(*pf)也是函数,pf就是函数指针。

其实知道规则以后,会非常易读。

由于前面还有一个int,也就是说,pfun是一个返回值为整型指针的函数。

如有如下的函数:intfn1(intx,inty);intfn2(intx);定义如下的函数指针:int(*p1)(inta,intb);int(*p2)(inta);则p1=fn1;//正确p2=fn2;//正确p1=fn2;//产生编译错误6)定义了一个函数指针并让它指向了一个函数后,对函数的调用可以通过函数名调用,也可以通过函数指针调用(即用指向函数的指针变量调用。

同样,我们把这个表达式改写一下:char*(*)(char*p1,char*p2)fun1;这样子是不是好看一些呢?只可惜编译器不这么想。

int*GetDate(intwk,intdy);main()先用字符型指针数组Names的地址来初始化指针nm。

为您推荐

发表回复

您的电子邮箱地址不会被公开。