注册 登录
编程论坛 C语言论坛

求助编译器问题

鱼头豆腐汤 发布于 2023-04-09 22:02, 1064 次点击
大佬们帮忙看看,arr数组里是上面注释里函数的编码,代码在vc6可以运行,vs2022编译通过,但运行时出现内存访问的错误,反汇编窗口可以call过去,但过去后单步就会直接ret,然后报异常。找了很多地方没找到问题,想了解一下vs出现这种情况的原因,还有解决办法。
程序代码:

#include <iostream>
/*int function(int x, int y)
{
    return x + y;
}
*/
unsigned char arr[] =
{
    0x55,0x8B,0xEC,0x81,0xEC,
    0xC0,0x00,0x00,0x00,0x53,
    0x56,0x57,0x8B,0x45,0x08,
    0x03,0x45,0x0C,0x5F,0x5E,
    0x5B,0x8B,0xE5,0x5D,0xC3
};

int main()
{
    int(*pfun)(int, int);
    pfun = (int(*)(int,int))&arr;
    int x = pfun(1,2);
    printf("%d", x);
    return 0;
}

反汇编窗口
只有本站会员才能查看附件,请 登录

出现错误
只有本站会员才能查看附件,请 登录
4 回复
#2
forever742023-04-09 22:30
越现代的系统对内存的使用权限的限制就越精细,这个是大势所趋。
个人认为弄死操作系统并没有什么好处。
所以研究上个世纪的老技术,还是去装一个老系统折腾吧。
#3
rjsp2023-04-10 09:24
2楼 forever74 说得对,你的arr所在内存没有可执行权限
另外,你的arr那段汇编是32位的,那你的VC工程平台也必须设为x86,不能是x64。

#include <stdio.h>
#include <string.h>
#include <windows.h>

unsigned char arr[] =
{
    0x55,0x8B,0xEC,0x81,0xEC,
    0xC0,0x00,0x00,0x00,0x53,
    0x56,0x57,0x8B,0x45,0x08,
    0x03,0x45,0x0C,0x5F,0x5E,
    0x5B,0x8B,0xE5,0x5D,0xC3
};

int main( void )
{
    void* p = VirtualAlloc( NULL, sizeof(arr), MEM_COMMIT|MEM_RESERVE,PAGE_EXECUTE_READWRITE );
    memcpy( p, arr, sizeof(arr) );

    int(*pfun)(int,int) = (int(*)(int,int))p;
    int x = pfun(1,2);
    printf( "%d\n", x );

    VirtualFree( p, NULL, MEM_RELEASE );
}
#4
鱼头豆腐汤2023-04-10 14:11
回复 2楼 forever74
好的,谢谢大佬
#5
鱼头豆腐汤2023-04-10 14:11
回复 3楼 rjsp
明白,谢谢大佬
1