为指针重载运算符++
overloading operator++ for a pointer
我需要循环通过一个内存区域,该区域包含我自己定义的类型:
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的(ModuleLList(和函数的大小(即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++;
但我觉得它看起来很难看。有什么建议吗?
C++要求运算符重载至少接受一个"类类型"或枚举类型的操作数。因此,您不能为内在/POD类型重载运算符,并且您需要用自制的智能指针类包装您的结构(正如Neil所建议的(。
相关文章:
- 使用C++中的模板和运算符重载执行矩阵运算
- 为什么这个运算符<重载函数对 STL 算法不可见?
- <T> 通过模板化运算符重载将 std::complex 乘以双倍
- C++20概念:需要运算符重载
- 使用赋值运算符重载从类中返回jobject
- 在运算符重载定义中使用成员函数(const错误)
- 字节到位运算符重载C++
- 为什么在运算符重载时需要参考?
- 类中 c++ 的运算符 + 重载
- 算术复合运算符重载为非成员
- 运算符重载 (+),用于添加两个具有 C++ 的数组
- 交换运算符 + 重载会导致无限递归
- 如何理解新的运算符重载?
- 向量保持复数的运算符重载
- 如何创建运算符重载?
- 链接列表运算符重载没有打印出我想要的内容
- C++:需要帮助了解运算符重载错误
- 使用模板化运算符重载 XOR 运算符失败
- 如何确保接受的C++模板类型使运算符重载?
- 运算符重载使用运算符+添加类模板