gpt4 book ai didi

c++ - 当我使用 void 函数的返回值(通过转换函数指针)时究竟会发生什么?

转载 作者:行者123 更新时间:2023-12-01 14:09:32 25 4
gpt4 key购买 nike

当我运行以下程序时,它总是打印"is"。但是当我改变时SOME_CONSTANT-2它总是打印“不”。这是为什么?我正在使用禁用优化的 Visual Studio 2019 编译器。

#define SOME_CONSTANT -3

void func() {
static int i = 2;
int j = SOME_CONSTANT;
i += j;
}

void main() {
if (((bool(*)())func)()) {
printf("yes\n");
}
else {
printf("no\n");
}
}

编辑:这是 func 的输出程序集(IDA 专业版 7.2):
sub     rsp, 18h
mov [rsp+18h+var_18], 0FFFFFFFEh
mov eax, [rsp+18h+var_18]
mov ecx, cs:i
add ecx, eax
mov eax, ecx
mov cs:i, eax
add rsp, 18h
retn

这是 main的第一部分:
sub     rsp, 628h
mov rax, cs:__security_cookie
xor rax, rsp
mov [rsp+628h+var_18], rax
call ?func@@YAXXZ ; func(void)
test eax, eax
jz short loc_1400012B0

这是主要的反编译:
int __cdecl main(int argc, const char **argv, const char **envp)
{
int v3; // eax

func();
if ( v3 )
printf("yes\n");
else
printf("no\n");
return 0;
}

最佳答案

((bool(*)())func)()

这个表达式需要一个指向 func 的指针, 将指针转换为不同类型的函数,然后调用它。通过函数签名与原始函数不匹配的函数指针调用函数是未定义的行为,这意味着任何事情都可能发生。从这个函数调用发生的那一刻起,就无法推断程序的行为。你无法确定地预测会发生什么。在不同的优化级别、不同的编译器、同一编译器的不同版本或针对不同的体系结构时,行为可能会有所不同。

这仅仅是因为允许编译器假设您不会这样做。当编译器的假设和现实发生冲突时,结果是一个真空,编译器可以插入任何它喜欢的东西。

对您的问题“为什么会这样?”的简单回答。很简单:因为它可以。但明天它可能会做别的事情。

关于c++ - 当我使用 void 函数的返回值(通过转换函数指针)时究竟会发生什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62169272/

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