#include “stdio.h”
#include “stdlib.h”
#include “Windows.h”
int go6688(int a, int b)
{
MessageBoxA(0, “劫持指令”, “你已经被劫持” ,0);
return 0;
}
int go(int a, int b)
{
printf(“haha\n”);
return 0;
}
void main()
{
int i = 1;
int (**p)(int a, int b) = &go;
*p = go6688; 代码执行到这里就报错了为什么?
printf(“%p %p”, go, go6688);
system(“pause”);
}
为什么二级函数指针修改不了函数指针变量的值?
操作系统问题?
本人用的win8
求各路高手解答!
#include “stdlib.h”
#include “Windows.h”
int go6688(int a, int b)
{
MessageBoxA(0, “劫持指令”, “你已经被劫持” ,0);
return 0;
}
int go(int a, int b)
{
printf(“haha\n”);
return 0;
}
void main()
{
int i = 1;
int (**p)(int a, int b) = &go;
*p = go6688; 代码执行到这里就报错了为什么?
printf(“%p %p”, go, go6688);
system(“pause”);
}
为什么二级函数指针修改不了函数指针变量的值?
操作系统问题?
本人用的win8
求各路高手解答!
解决方案
20
这样不就行了?
#include "stdio.h" #include "stdlib.h" #include "Windows.h" int go6688(int a, int b) { MessageBoxA(0, "劫持指令", "你已经被劫持" ,0); return 0; } int go(int a, int b) { printf("haha\n"); return 0; } void main() { int i = 1; int (*p)(int a, int b) = &go; p = go6688; printf("%p %p\n", go, go6688); system("pause"); }
2
理解和讨论之前请先学会怎么样观察!
计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……
对学习编程者的忠告:
多用小脑和手,少用大脑、眼睛和嘴,会更快地学会编程!
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步Debug版对应汇编一行!
单步Debug版对应汇编千行不如单步Release版对应汇编一行!
不会单步Release版对应汇编?在你想单步Release版C/C++代码片断的前面临时加一句DebugBreak();重建全部,然后在IDE中运行。(一般人本人不告诉他!)
VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或在某行按F9设了断点后按F5执行停在该断点处的时候。
计算机组成原理→DOS命令→汇编语言→C语言(不包括C++)、代码书写规范→数据结构、编译原理、操作系统→计算机网络、数据库原理、正则表达式→其它语言(包括C++)、架构……
对学习编程者的忠告:
多用小脑和手,少用大脑、眼睛和嘴,会更快地学会编程!
眼过千遍不如手过一遍!
书看千行不如手敲一行!
手敲千行不如单步一行!
单步源代码千行不如单步Debug版对应汇编一行!
单步Debug版对应汇编千行不如单步Release版对应汇编一行!
不会单步Release版对应汇编?在你想单步Release版C/C++代码片断的前面临时加一句DebugBreak();重建全部,然后在IDE中运行。(一般人本人不告诉他!)
VC调试时按Alt+8、Alt+7、Alt+6和Alt+5,打开汇编窗口、堆栈窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应堆栈、内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或在某行按F9设了断点后按F5执行停在该断点处的时候。
20
int (*p)(int a, int b) = &go;
int (**pp)(int a, int b) = &p;
int (**pp)(int a, int b) = &p;
4
不是int (*p)(int a, int b) = &&go;
而是int (*p)(int a, int b) = &go;
而是int (*p)(int a, int b) = &go;
16
原因是 你的 *p 访问的地址不合法,想用的话你得先分配个内存给他才能解除引用,用楼上说的那种一级指针吧,这种纯属没事找事