1.代碼


















































2.結(jié)果
B::fun1
B::fun2
f1 = 004010AA f2 = 004010B4
B::fun1 = 004010AA, B::fun2 = 004010B4
3.解惑
i. 如果對(duì)于為什么f = A::funx 卻輸出的是B::funx?
ii. 為什么A::funx = B::funx
以上兩個(gè)問(wèn)題可以當(dāng)作是一個(gè),看看匯編就知道了,他們將生成一個(gè)虛函數(shù)的選擇函數(shù),短小的函數(shù)負(fù)責(zé)選對(duì)應(yīng)虛函數(shù)中的位置,根據(jù)對(duì)象的虛函數(shù)表而定,所以....
4.匯編
debug
0040121E . C745 F0 AA104>mov dword ptr [ebp-10], 004010AA
00401225 . C745 EC B4104>mov dword ptr [ebp-14], 004010B4
0040122C . 8BF4 mov esi, esp
0040122E . 8B4D E8 mov ecx, [ebp-18]
00401231 . FF55 F0 call [ebp-10]
00401234 . 3BF4 cmp esi, esp
00401236 . E8 A5870000 call _chkesp
0040123B . 8BF4 mov esi, esp
0040123D . 8B4D E8 mov ecx, [ebp-18]
00401240 . FF55 EC call [ebp-14]
00401243 . 3BF4 cmp esi, esp
00401245 . E8 96870000 call _chkesp
0040124A . 8B55 EC mov edx, [ebp-14]
0040124D . 52 push edx ; /<%p>
0040124E . 8B45 F0 mov eax, [ebp-10] ; |
00401251 . 50 push eax ; |<%p>
00401252 . 68 48404300 push 00434048 ; |format = "f1 = %p f2 = %p",LF,""
00401257 . E8 14820000 call printf ; \printf
0040125C . 83C4 0C add esp, 0C
0040125F . 68 B4104000 push 004010B4 ; /<%p> = Cplusplu.004010B4
00401264 . 68 AA104000 push 004010AA ; |<%p> = Cplusplu.004010AA
00401269 . 68 24404300 push 00434024 ; |format = "B::fun1 = %p, B::fun2 = %p",LF,""
0040126E . E8 FD810000 call printf ; \printf
00402300 > > \8B01 mov eax, [ecx] // 第一個(gè)虛函數(shù)
00402302 . FF20 jmp [eax]
00402304 CC int3
00402305 CC int3
00402306 CC int3
00402307 CC int3
00402308 CC int3
00402309 CC int3
0040230A CC int3
0040230B CC int3
0040230C CC int3
0040230D CC int3
0040230E CC int3
0040230F CC int3
00402310 > > 8B01 mov eax, [ecx] // 第二個(gè)虛汗數(shù)
00402312 . FF60 04 jmp [eax+4]
release
00401019 |> \33F6 xor esi, esi
0040101B |> 8BCE mov ecx, esi
0040101D |. E8 5E060000 call 00401680
00401022 |. 8BCE mov ecx, esi
00401024 |. E8 67060000 call 00401690
00401029 |. 68 90164000 push 00401690 ; Entry address
0040102E |. 68 80164000 push 00401680 ; Entry address
00401033 |. 68 C4F04000 push 0040F0C4 ; ASCII "f1 = %p f2 = %p",LF
00401038 |. E8 2D310000 call 0040416A
0040103D |. 83C4 0C add esp, 0C
00401040 |. 68 90164000 push 00401690 ; Entry address
00401045 |. 68 80164000 push 00401680 ; Entry address
0040104A |. 68 A8F04000 push 0040F0A8 ; ASCII "B::fun1 = %p, B::fun2 = %p",LF
0040104F |. E8 16310000 call 0040416A
00401680 $ 8B01 mov eax, [ecx]
00401682 . FF20 jmp [eax]
00401684 CC int3
00401685 CC int3
00401686 CC int3
00401687 CC int3
00401688 CC int3
00401689 CC int3
0040168A CC int3
0040168B CC int3
0040168C CC int3
0040168D CC int3
0040168E CC int3
0040168F CC int3
00401690 $ 8B01 mov eax, [ecx]
00401692 . FF60 04 jmp [eax+4]