久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

標題: Protel 99 SE報錯 'Format '%x' invalid or incompatible with argument' 的分析 [打印本頁]

作者: 交通燈    時間: 2018-6-25 23:15
標題: Protel 99 SE報錯 'Format '%x' invalid or incompatible with argument' 的分析
Protel 99 SE報錯 'Format '%x' invalid or incompatible with argument' 的分析之前在筆記本上從來沒出現過這個問題, 相同的安裝文件. 已經打了protel99seservicepack6的補丁. 換了4核的臺式機基本每天都有幾次...
        這個問題在網上搜索, 回答多是不能用太好的機器否則Protel 99 SE 就會有很多問題, 經過分析實際還真是這樣的.
Od載入 Client99SE.exe 斷點到 Kernel32->RaiseException, 因為這是個delphi未處理異常. 運行進程等待 Client99SE.exe 拋出異常.
當調用RaiseException 時查看調用棧定位到函數
0DF61357    55                   push    ebp
0DF61358    68 9414F60D          push    0DF61494
0DF6135D    64:FF30              push    dword ptr fs:[eax]
0DF61360    64:8920              mov     dword ptr fs:[eax], esp
0DF61363    C606 00              mov     byte ptr [esi], 0
0DF61366    E8 CD03E9FF          call    <jmp.&kernel32.GetTickCount>
0DF6136B    8BD8                 mov     ebx, eax
0DF6136D    8D85 FCFEFFFF        lea     eax, dword ptr [ebp-104]
0DF61373    50                   push    eax
0DF61374    A1 7CF1F70D          mov     eax, dword ptr [DF7F17C]
0DF61379    83C0 11              add     eax, 11
0DF6137C    8985 E4FEFFFF        mov     dword ptr [ebp-11C], eax
0DF61382    C685 E8FEFFFF 04     mov     byte ptr [ebp-118], 4
0DF61389    C685 ECFEFFFF 7E     mov     byte ptr [ebp-114], 7E
0DF61390    C685 F0FEFFFF 02     mov     byte ptr [ebp-110], 2
0DF61397    899D F4FEFFFF        mov     dword ptr [ebp-10C], ebx
0DF6139D    C685 F8FEFFFF 00     mov     byte ptr [ebp-108], 0
0DF613A4    8D95 E4FEFFFF        lea     edx, dword ptr [ebp-11C]
0DF613AA    B9 02000000          mov     ecx, 2
0DF613AF    B8 AC14F60D          mov     eax, 0DF614AC                                 ; ASCII "%s\%s%x.tmp"
0DF613B4    E8 0703E9FF          call    <jmp.&Vcl50.Sysutils::Format>
0DF613B9    8B95 FCFEFFFF        mov     edx, dword ptr [ebp-104]
0DF613BF    8D85 00FFFFFF        lea     eax, dword ptr [ebp-100]
0DF613C5    B9 FF000000          mov     ecx, 0FF
0DF613CA    E8 71FEE8FF          call    <jmp.&Vcl50.System::LStrToString>
0DF613CF    EB 69                jmp     short 0DF6143A
0DF613D1    E8 6203E9FF          call    <jmp.&kernel32.GetTickCount>
0DF613D6    8BD8                 mov     ebx, eax
0DF613D8    8D85 E0FEFFFF        lea     eax, dword ptr [ebp-120]
0DF613DE    50                   push    eax
0DF613DF    A1 7CF1F70D          mov     eax, dword ptr [DF7F17C]
0DF613E4    83C0 11              add     eax, 11
0DF613E7    8985 E4FEFFFF        mov     dword ptr [ebp-11C], eax
0DF613ED    C685 E8FEFFFF 04     mov     byte ptr [ebp-118], 4
0DF613F4    C685 ECFEFFFF 7E     mov     byte ptr [ebp-114], 7E
0DF613FB    C685 F0FEFFFF 02     mov     byte ptr [ebp-110], 2
0DF61402    899D F4FEFFFF        mov     dword ptr [ebp-10C], ebx
0DF61408    C685 F8FEFFFF 00     mov     byte ptr [ebp-108], 0
0DF6140F    8D95 E4FEFFFF        lea     edx, dword ptr [ebp-11C]
0DF61415    B9 02000000          mov     ecx, 2
0DF6141A    B8 C014F60D          mov     eax, 0DF614C0                                 ; ASCII "%s\s%x%.tmp"
0DF6141F    E8 9C02E9FF          call    <jmp.&Vcl50.Sysutils::Format>
0DF61424    8B95 E0FEFFFF        mov     edx, dword ptr [ebp-120]
0DF6142A    8D85 00FFFFFF        lea     eax, dword ptr [ebp-100]
0DF61430    B9 FF000000          mov     ecx, 0FF
0DF61435    E8 06FEE8FF          call    <jmp.&Vcl50.System::LStrToString>
0DF6143A    8D85 DCFEFFFF        lea     eax, dword ptr [ebp-124]
0DF61440    8D95 00FFFFFF        lea     edx, dword ptr [ebp-100]
0DF61446    E8 EDFDE8FF          call    <jmp.&Vcl50.System::LStrFromString>
0DF6144B    8B85 DCFEFFFF        mov     eax, dword ptr [ebp-124]
0DF61451    E8 B201E9FF          call    <jmp.&Vcl50.Sysutils::FileExists>
0DF61456    84C0                 test    al, al
0DF61458  ^ 0F85 73FFFFFF        jnz     0DF613D1
0DF6145E    8BC6                 mov     eax, esi
0DF61460    8D95 00FFFFFF        lea     edx, dword ptr [ebp-100]
0DF61466    E8 2DFCE8FF          call    <jmp.&Vcl50.System::PStrCpy>
0DF6146B    33C0                 xor     eax, eax
0DF6146D    5A                   pop     edx
0DF6146E    59                   pop     ecx
0DF6146F    59                   pop     ecx
0DF61470    64:8910              mov     dword ptr fs:[eax], edx
0DF61473    68 9B14F60D          push    0DF6149B
0DF61478    8D85 DCFEFFFF        lea     eax, dword ptr [ebp-124]
0DF6147E    BA 02000000          mov     edx, 2
0DF61483    E8 90FDE8FF          call    <jmp.&Vcl50.System::LStrArrayClr>
0DF61488    8D85 FCFEFFFF        lea     eax, dword ptr [ebp-104]
0DF6148E    E8 7DFDE8FF          call    <jmp.&Vcl50.System::LStrClr>
0DF61493    C3                   retn
0DF61494  ^ E9 3FFDE8FF          jmp     <jmp.&Vcl50.System::HandleFinally>
0DF61499  ^ EB DD                jmp     short 0DF61478
0DF6149B    5E                   pop     esi
0DF6149C    5B                   pop     ebx
0DF6149D    8BE5                 mov     esp, ebp
0DF6149F    5D                   pop     ebp
0DF614A0    C3                   retn
堆棧上有一塊字符串
0013DD1C   0F817B8C  ASCII "C:\PROGRA~1\DESIGN~1\\System\Temp\~35C52FB.tmp"
問題出在第二個調用format函數時給予的第一個參數 "%s\s%x%.tmp" 上.
用ida插件轉換到c代碼
int __fastcall sub_571334(int a1)
{
  int v1; // esi@1
  int v2; // ST04_4@1
  DWORD v4; // eax@1
  DWORD v5; // eax@2
  int v6; // [sp+8h] [bp-124h]@1
  int v7; // [sp+Ch] [bp-120h]@1
  int v8; // [sp+28h] [bp-104h]@1
  int v9; // [sp-Ch] [bp-138h]@1
  int v10; // [sp+10h] [bp-11Ch]@1
  char v11; // [sp+14h] [bp-118h]@1
  char v12; // [sp+18h] [bp-114h]@1
  char v13; // [sp+1Ch] [bp-110h]@1
  DWORD v14; // [sp+20h] [bp-10Ch]@1
  char v15; // [sp+24h] [bp-108h]@1
  char v16; // [sp+2Ch] [bp-100h]@1

  v6 = 0;
  v7 = 0;
  v8 = 0;
  v1 = a1;
  v2 = *MK_FP(__FS__, 0);
  *MK_FP(__FS__, 0) = &v9;
  *(_BYTE *)a1 = 0;
  v4 = GetTickCount();
  v10 = dword_58F17C + 17;
  v11 = 4;
  v12 = 126;
  v13 = 2;
  v14 = v4;
  v15 = 0;
  Sysutils__Format(&str__s__s_x_tmp[1], &v10, &v8);
  System____linkproc___LStrToString(&v16, v8);
  while ( 1 )
  {
    System____linkproc___LStrFromString(&v6, &v16);
    if ( !(unsigned __int8)Sysutils__FileExists(v6) )
      break;
    v5 = GetTickCount();
    v10 = dword_58F17C + 17;
    v11 = 4;
    v12 = 126;
    v13 = 2;
    v14 = v5;
    v15 = 0;
    Sysutils__Format(&str__s_s_x__tmp[1], &v10, &v7);
    System____linkproc___LStrToString(&v16, v7);
  }
  System____linkproc___PStrCpy(v1, &v16);
  *MK_FP(__FS__, 0) = v2;
  System____linkproc___LStrArrayClr(&v6, 2);
  return System____linkproc___LStrClr(&v8);
}
可以看到這個函數用來完成生成不重復的隨機文件名, 當機器太快硬盤太快時GetTickCount返回的值可能在兩次調用中相同, 就會調用第二個format發生這個異常 因為Sysutils__Format(&str__s_s_x__tmp[1], &v10, &v7);處參數是錯誤的.
只要補丁字符串 "%s\s%x%.tmp" 為 "%s\%s%x.tmp" 就可以了.
原來是寫 Protel 99 SE 的大神當年沒測試到...


點擊打開補丁,進入補丁畫面,點開始,進入99SE安裝文件夾,找到ADVPCB.DLL的程序,點擊打開,關閉后退出,重新打開99SE 就行了



Protel 99se補丁.rar

37.2 KB, 下載次數: 84, 下載積分: 黑幣 -5


作者: Ryan071118    時間: 2019-11-5 08:35
安裝好立馬解決問題,感謝!
作者: masonled    時間: 2019-12-26 13:11
怎么下載不了
作者: ly1972001    時間: 2019-12-26 14:33
為啥用99,AD不是很好嗎?
作者: allencz    時間: 2021-3-10 15:20
太感謝了,正為這事發愁呢,原來電腦太快也有不好的地方,吼吼
作者: yzxky    時間: 2021-6-14 11:35
ly1972001 發表于 2019-12-26 14:33
為啥用99,AD不是很好嗎?

因為當時好多程序都是基于99開發的,AD不好用啊
作者: CIKAR    時間: 2021-10-9 17:30
贊一個,今天遇到兩次了,完美解決

作者: wuyibin2003    時間: 2023-7-1 12:59
試試看 好久沒有用這個軟件了
作者: 都市郎(新)    時間: 2023-7-10 01:16
誰有protel 99se的加庫工具軟件?
作者: 都市郎(新)    時間: 2023-7-10 01:20
我還是喜歡用protel 99se少巧,業余夠用。AD太大太卡,不是天天畫板用不上,軟件老是更新,學軟件都學殘廢了。




歡迎光臨 (http://www.zg4o1577.cn/bbs/) Powered by Discuz! X3.1
主站蜘蛛池模板: 国产专区在线 | 天天影视色综合 | 国产一区 日韩 | 成人在线视 | 日韩网站在线观看 | 国产欧美日韩精品一区 | 91精品国产91久久久久久吃药 | 久久久久久久国产精品视频 | 国产精品国产三级国产aⅴ中文 | 亚洲精品美女视频 | 精品日韩一区 | 精品日韩在线 | 亚洲色图50p| 国产精品久久 | 欧美一区二区三区电影 | 国产高清免费视频 | 国产一区二区三区不卡av | 日韩精品免费 | hsck成人网| 黄色电影在线免费观看 | 日韩免费高清视频 | 一级电影免费看 | 91美女在线观看 | 亚洲日韩中文字幕一区 | 欧美久久一级特黄毛片 | www国产亚洲精品久久网站 | 色婷婷精品国产一区二区三区 | 欧美最猛黑人 | 天天草狠狠干 | 最新中文字幕 | 亚洲欧美在线观看 | 国产99免费视频 | 日韩中文一区二区三区 | 精品国产一区探花在线观看 | 色网站视频 | 国产黄色大片网站 | 日本精品视频 | avmans最新导航地址 | 亚洲一区二区av | 久久视频精品 | 日本三级在线 |