0

我有以下代码

void PacketEncrypt(Packet* packet, int sizeofpacket)
{
    int* pointer;
    pointer = ((int*)packet+sizeofpacket)-2;
    (int)*pointer = packet->PacketSize^0x1A3C;
    packet->Type += 0x0FFF7;
}

问题是当我调试它时编译器将其设置为:

0041585E   8B45 0C          MOV EAX,DWORD PTR SS:[EBP+C]
00415861   8B4D 08          MOV ECX,DWORD PTR SS:[EBP+8]
00415864   8D5481 F8        LEA EDX,DWORD PTR DS:[ECX+EAX*4-8]

但我真正想要的是:

0041585E   8B45 0C          MOV EAX,DWORD PTR SS:[EBP+C]
00415861   8B4D 08          MOV ECX,DWORD PTR SS:[EBP+8]
00415864   8D5481 F8        LEA EDX,DWORD PTR DS:[ECX+EAX-2]

我是 C++ 的新手,所以你能帮我解决我做错了什么,或者为什么编译器要添加标量 *4?谢谢 !

4

2 回答 2

4

C++ 使用指针类型进行指针运算。ptr+2是 2 个元素,而不是过去的两个字节ptr。如果sizeof(*ptr)==4,这两个元素是 8 个字节,ptr+2因此将指向 8 个字节过去ptr

于 2012-07-24T07:04:40.567 回答
1

int指针4 bytes在您的机器上的大小为 ,只能按4*n字节移动。如果您需要通过强制转换来移动指针2 byteschar因为sizeof(char) = 1

char *ptr = (char*)otherPtr;
ptr += 2; //shift by 2 bytes

int *ptr = (int*)otherPtr;
ptr += 2; //shift by 8 bytes. (2 * sizeof(int))

编辑

(short*)pointer = something.- 你不能分配给rvalue. 我想你的意思是:

pointer = (char*) something

或者,如果您需要short指针:

short *someOtherPointer = something 
于 2012-07-24T07:04:08.117 回答