C++内存编辑 - 写入当前程序

C++ Memory Editing- Writing to current program

本文关键字:前程 程序 内存 编辑 C++      更新时间:2023-10-16

我的代码是-

BYTE newValue[] = {0x90, 0x90, 0x90, 0x90};
*(char *)0x004C40DB = &newValue;

我正在尝试将004C40DB设置为nop.

在Visual C++ 2010中,我得到-

1>------ 构建开始:项目:文件,配置:发布Win32

1> 文件.cpp 1>文件.cpp(138(:错误 C2440:"=":无法从 转换 "字节 (*([4]" 到 "字符">

1> 没有上下文可以进行这种转换

1>file.cpp(142(: 错误 C2440: '=' : 无法从"字节 (*([4]' 转换 到"字符">

1> 没有上下文可以进行这种转换

==========

构建:0 成功,1 失败,0 最新,0 跳过 ====

======

我做错了什么?

首先,为了你自己起见,使用C++式的强制转换。

其次,如果你想写一个0x90,为什么你有一个包含四个的数组?一个就够了:

*reinterpret_cast<char *>(0x004C40DB) = 0x90;

但是您很可能需要使用WriteProcessMemory,如另一个问题中所述,并且您需要首先通过使用VirtualProtect使内存可写。

最后,如果你真的需要写入多个字节,你需要注意匹配的数据类型——你不能将指针到字节写入单个字节。使用WriteProcessMemory,您将传递正确的大小。

如果在自己的进程中写入内存,则改用std::copy

这是你想做的吗?

BYTE newValue[] = {0x90, 0x90, 0x90, 0x90};
*(long*)0x004C40DB = *(long*)newValue;

如果您尝试复制四个字节,那么您需要指向 long 的指针而不是指向 char 的指针(假设 long 是四个字节(。