gpt4 book ai didi

c - 这种将 char 数组转换为函数的调用有何作用?

转载 作者:行者123 更新时间:2023-12-01 23:46:53 24 4
gpt4 key购买 nike

我遇到了这段代码:

char code[] = "\xb0\x01\x31\xdb\xcd\x80";
int main(int argc, char **argv)
{
int (*func)();
func = (int (*)()) code;
(int)(*func)();
}

复制自Writing Shellcode for Linux and Windows Tutorial .

谁能解释一下这个函数调用 (int)(*func)(); 是做什么的?

最佳答案

它调用一个函数,其机器代码在数组code 中。 string 包含一些机器级指令((我认为是三个,看看 x86 指令集)。func 被声明为指向不带参数的函数的指针并返回一个 int。然后 func 被设置为该 string 的第一个字节的地址(机器指令记得)。然后 func 被调用,因此对 string 的第一条指令进行了函数调用。

我现在对x86指令集不是很了解,但是好像要进行系统调用(不知道是哪个); 0xcd 0x80 是系统的陷阱。


正如@eteranger所说,它是对_exit系统调用的调用。

注意这是依赖于 Linux 的,参见 What does "int 0x80" mean in assembly code?

此处提供了此机制的简短说明:http://www.linfo.org/system_call_number.html

关于c - 这种将 char 数组转换为函数的调用有何作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28668138/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com