C++中这些代码不太懂啊,帮我看看!

better0332 2006-12-24 03:51:36
_declspec(dllimport) int add(int a,int b);
HINSTANCE hInst;
hInst=LoadLibrary("Dll.dll");
typedef int (*ADDPROC)(int a,int b);//这句实在看不懂!
ADDPROC Add=(ADDPROC)GetProcAddress(hInst,"add");
Add(5,3);

还有

char shellcode[] ="……“;
int (*pfunc)();
pfunc=(int(*)())shellcode;
(int)(*pfunc)();
为什么上面的代码执行后就能执行shellcode数组中的代码??

麻烦大家帮我解释一下…………
...全文
242 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
Jedimaster 2006-12-25
  • 打赏
  • 举报
回复
typedef int (*ADDPROC)(int a,int b);//这句实在看不懂!

这是函数指针,最好拿回你的教材重新复习一下

WIN32中有很多函数指针都是声明为PFN的前缀
gaoyinxin 2006-12-25
  • 打赏
  • 举报
回复
((void(*)(void))&ShellCode)();
就是(void(*)())吧。而且c里void形参可以以接受int
better0332 2006-12-24
  • 打赏
  • 举报
回复
谢谢大家了,第一段代码我懂了,第二段还有一点疑问
int (*) ( int, int )知道是函数指针,但好像没有名称!
((void(*)(void))&ShellCode)();
也能直接运行数组中的代码,这又怎么解释??
htqx 2006-12-24
  • 打赏
  • 举报
回复

int add(int a,int b);
这个函数的类型是 int ( int, int );
指向这个类型的指针可以使用这个函数,指针的类型是:
int (*) ( int, int );

(*)这个是指针的定义符号,然后括号是改变顺序,如果没有,那么就是一个返回int* 的函数,而不是指针了。

typedef int (*ADDPROC)(int a,int b);

typedef 是给类型起一个名称,这个名称的位置同时也是一般变量名的问题。这里是 ADDPROC

ADDPROC Add ;

定义变量,这个变量可以调用函数:

Add(5,3); //实际是调用 int add(int a,int b);
ruidiisy 2006-12-24
  • 打赏
  • 举报
回复
函数指针
caocheng8230 2006-12-24
  • 打赏
  • 举报
回复
教你最简单的办法
就是
int add(int a,int b);
然后打开project->setting->Link
在当中把Dll.dll加入到当中
然后确定退出,
在程序当中就可以直接使用add了
  • 打赏
  • 举报
回复
char shellcode[] ="……“;
int (*pfunc)();
pfunc=(int(*)())shellcode;
(int)(*pfunc)();
为什么上面的代码执行后就能执行shellcode数组中的代码??
pfunc是个函数指针,指向shellcode
(int)(*pfunc)();这一行应该是调用吧,没见过这样写的一般这样写pfunc();
  • 打赏
  • 举报
回复
typedef int (*ADDPROC)(int a,int b);//这句实在看不懂!
声明一个函数指针类型 类型名字ADDPROC

64,281

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧