全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1704
推到 Plurk!
推到 Facebook!

程式執行到 CoUnInitialize; 時出現 "Access violation" 的錯誤

尚未結案
kyxiang
一般會員


發表:8
回覆:6
積分:2
註冊:2002-03-11

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-03-01 16:08:15 IP:210.59.xxx.xxx 未訂閱
我的程式碼如下 :  
 
  CoInitialize(nil);
  Excel:=CreateOleObject('Excel.Application');
  Try
    .
    .
    .
    ShowMessage('Excel 檔輸出完成 !!');
  Finally
    Excel.Quit;
    VarClear(Excel);        CoUnInitialize;
  end;
但是程式執行到 CoUnInitialize; 時會出現 "Access violation" 的錯誤 請問這是什麼原因呢? 另, 為什麼有時候在 Excel:=CreateOleObject('Excel.Application'); 之前可以不用呼叫初始化函數也不會有問題, 而有時候則必須要先呼叫初始化函數, 否則會出現 "Moniker並未參照到存放庫" 的錯誤訊息?? 請各位先進不吝為小弟解惑.. 謝謝 !!
william
版主


發表:66
回覆:2535
積分:3048
註冊:2002-07-11

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-03-14 15:22:52 IP:147.8.xxx.xxx 未訂閱
引言: 我的程式碼如下 :
 
  CoInitialize(nil);
  Excel:=CreateOleObject('Excel.Application');
  Try
    .
    .
    .
    ShowMessage('Excel 檔輸出完成 !!');
  Finally
    Excel.Quit;
    VarClear(Excel);        CoUnInitialize;
  end;
但是程式執行到 CoUnInitialize; 時會出現 "Access violation" 的錯誤 請問這是什麼原因呢? No idea. But if Excel is a local variant variable, I think you should leave it alone since the proecdure will destroy it at the end. Try removing the line "VarClear(Excel)" and probably the CoInitialize and CoUnitialize if you are not using COM within a thread. 另, 為什麼有時候在 Excel:=CreateOleObject('Excel.Application'); 之前可以不用呼叫初始化函數也不會有問題, 而有時候則必須要先呼叫初始化函數, 否則會出現 "Moniker並未參照到存放庫" 的錯誤訊息?? Because the related units you probably used (e.g. COMObj) has the proper initialization/finalization section to do all the works for you. However, if you want to use COM within a thread (except main thread), you need to do it yourself. 請各位先進不吝為小弟解惑.. 謝謝 !!
系統時間:2024-04-28 8:53:44
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!