我需要遍历包含我自己定义的类型的内存区域:
struct ModuleList
{
char ModuleName[64];
int32_t NumberOfFunctions;
};
struct FunctionList
{
char FunctionName[64];
DWORD FunctionAddress;
};
这些在内存中的布局如下:
0: ModuleList[0]
0 + sizeof(ModuleList): FunctionsList[NumberOfFunctions]
0 + sizeof(ModuleList)+ NumberOfFunctions * sizeof(FunctionList): ModuleList[1]
.
.
.
我想做的是,将ModuleList *的运算符++重载,这样我就可以轻松地正确地增加指针,因为指针的默认++运算符仅对sizeof(ModuleList)递增,而我想对sizeof(ModuleList)递增。和功能的大小(即NumberOfFunctions * sizeof(FunctionList))。内存中的这些结构是完全动态的,我的程序通过网络获取这些结构。 目前,我正在这样做:
unsigned short ModuleCount = 0;
BYTE* pTemp = (BYTE*)MemoryAdr;
for (; std::string(((ModuleList*)(pTemp))->ModuleName).find(".dll") != std::string::npos; pTemp += ModuleListSize + ((ModuleList*)(pTemp))->NumberOfFunctions * FunctionListSize)
ModuleCount++;
但我认为它看起来很丑。有什么建议吗?
答案 0 :(得分:2)
C ++要求您的运算符重载至少要使用一个“类类型”或枚举类型的操作数。因此,您不能为内在/ POD类型重载运算符,而需要用自制的智能指针类包装结构(如Neil所建议的那样)。