这里要注意的是,虽然图中显示IY的虚函数表中QueryInterface,AddRef和Release指向的
函数地址与IX的虚函数表中对应函数相同,都直接指向CA::QueryInterface等。
但其实并不完全是这样。如果看汇编实现,可以看到
IY中的AddRef指向的地址是这样:
[thunk]:CA::AddRef`adjustor{4}':
00401740 sub ecx,4
00401743 jmp CA::AddRef (4015E0h)
它会把ecx减4(ecx存放this指针),即将 IY::this 转为 CA::this,然后再调用 CA::AddRef
对于IX::AddRef就不需要这样处理了
相关代码: