锘??xml version="1.0" encoding="utf-8" standalone="yes"?>
TO:鐢║E淇敼Windows 2000 Professional.vmx鏂囦歡,澧炲姞
vmmouse.present = FALSE
svga.maxFullscreenRefreshTick = 5
鍏堟潵鐪嬬湅澶氶噸緇ф壙鐨勫璞$粍緇囩殑緇撴瀯
瀹為檯涓婏紝澶氶噸緇ф壙vc閮藉皢瀹冭В閲婁負榪欎釜緇撴瀯銆備絾鏄閲嶉泦鎴愪腑瀹為檯鍦ㄥ唴瀛樹腑鐨勭粍緇囨槸寰堜笉涓鏍風殑
00B606D8 0046F020 offset test3.D::`vftable'
00B606DC CDCDCDCD A::a
00B606E0 CDCDCDCD B::b
00B606E4 0046F01C offset test3.D::`vftable'
00B606E8 CDCDCDCD A::a
00B606EC CDCDCDCD C::c
00B606F0 CDCDCDCD D::d
note:
鎸夌収閬撶悊鏉ヨ涓や釜offset test3.D::`vftable'搴旇鎸囧悜鍚屼竴涓湴鏂規(guī)墠瀵癸紝鍙繖閲屾槸錛?br>
絎簩涓猳ffset test3.D::`vftable'鎸囧悜鐨勪綅緗槸絎簩綃囪榪囩殑璺寵漿鍑芥暟錛?br>
2.铏氱戶鎵?br>
00A806D8 0046F02C offset test3.D::`vbtable'
00A806DC CDCDCDCD B::b
00A806E0 0046F020 offset test3.D::`vbtable'
00A806E4 CDCDCDCD C::c
00A806E8 CDCDCDCD A::a
00A806EC 0046F01C offset test3.D::`vftable'
00A806F0 CDCDCDCD D::d
絎竴鍜岀浜屼釜offset test3.D::`vbtable' 鎸囧悜涓涓亸縐昏煩杞〃錛屽畠鐨勮〃涓敤鍋忕Щ鎸囧悜浜嗙湡姝g殑offset test3.D::`vbtable'錛岀涓変釜鏄湡姝g殑offset test3.D::`vbtable'鍦板潃
0046F01C >004011A9 test3.004011A9 絎笁涓猳ffset test3.D::`vbtable'
0046F020 >00000000 絎簩涓猳ffset test3.D::`vbtable'
0046F024 0000000C 鍋忕ЩC
0046F028 00000000
0046F02C >00000000 絎竴涓猳ffset test3.D::`vbtable'
0046F030 00000014 渚垮疁14
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] // 絎竴涓櫄鍑芥暟
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] // 絎簩涓櫄姹楁暟
00402312 . FF60 04 jmp [eax+4]
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]