我写了一些代码来知道函数指针是如何工作的。 我在一些IDE上运行以下C++代码,结果是一样的。C++中函数指针的指针
#include "stdafx.h"
int *function(){
static int a=1;
return &a;
}
typedef struct{
int *(*pt_1)();
int *(*pt_2)();
}x_t;
int _tmain(int argc, _TCHAR* argv[])
{
x_t s;
s.pt_1 = function;
s.pt_2 = &function;
printf("%x\n",s.pt_1); //Result: 0x013011a9
printf("%x\n",*s.pt_1); //Result: 0x013011a9
printf("%x\n",**s.pt_1); //Result: 0x013011a9
printf("%x\n",s.pt_1()); //Result: 0x01307000
printf("%x\n",*s.pt_1()); //Result: 1
printf("%x\n",s.pt_2); //Result: 0x013011a9
printf("%x\n",*s.pt_2); //Result: 0x013011a9
printf("%x\n",**s.pt_2); //Result: 0x013011a9
printf("%x\n",s.pt_2()); //Result: 0x01307000
printf("%x\n",*s.pt_2()); //Result: 1
return 0;
}
我的问题:
-
- 为什么
s.pt_1 == s.pt_2 == *s.pt_1 = **s.pt_1
?
- 为什么
-
- 凡地址是否
s.pt_1()
点?它在哪里找到内存?
1,请参阅[this](http://stackoverflow.com/questions/2795575/how-does-dereferencing-of-a-function-pointer-happen)。 2. operator()调用函数,所以你正在处理它的返回指针。 – LogicStuff
由'%x'打印函数指针会调用未定义的行为,因为地址可能不适合'int'。使用'printf(“%p \ n”,(void *)s。' –
我在这里找到了第二个问题的答案[内存中的内存是否存储在内存中的返回值?](http://stackoverflow.com/questions/5472008/where-in-memory-are-return-values -stored式存储器) –