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

如何一次CLOSE掉多個Table

答題得分者是:Vicen
Leonli
一般會員


發表:23
回覆:21
積分:18
註冊:2004-03-31

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-11-19 18:59:42 IP:222.90.xxx.xxx 未訂閱
我在程式的一個From裏面放了一大堆Table(BDE的),我想在程式執行完畢後,將所有的Table都Close掉,如何可以一次把他CLOSE掉。不要一張表一張表的做。
Vicen
高階會員


發表:13
回覆:145
積分:151
註冊:2005-03-14

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-11-19 20:50:22 IP:221.226.xxx.xxx 未訂閱
有借就要有还,有开就必须有关,这是写程序所必须的良好习惯,申请了内存/控件/变量就必须释放,而文件/数据库开了就必须关闭,开多少就应该手动关多少,否则很容易引起文件或库损坏,还会引起内存泄漏,不要怕麻烦,这是必须的. 發表人 - vicen 於 2005/11/19 20:52:55
huangeider
高階會員


發表:288
回覆:492
積分:231
註冊:2003-02-26

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-11-19 20:55:37 IP:218.172.xxx.xxx 未訂閱
procedure TForm1.BitBtn1Click(Sender: TObject); var i:integer; begin for i:=0 to Componentcount-1 do begin if Components[i] is Ttable then begin Ttable(Components[i]).Close; end; end; end;
kgt
高階會員


發表:17
回覆:308
積分:165
註冊:2002-03-13

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-11-20 07:30:10 IP:61.219.xxx.xxx 未訂閱
建議已確定不用的部分,在當下就應該CLOSE,而非在整個程式CLOSE時,才一次 全部關閉,原因在未來您不論使用何種後端DB,會耗用後端RESOURCE,又當每個用相同程式的人也是用此方式時,未來所需付出的硬體及軟體成本是可觀的。
digitraveler
初階會員


發表:89
回覆:91
積分:46
註冊:2005-06-01

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-11-20 09:03:42 IP:211.21.xxx.xxx 未訂閱
*.exe 在結束時,自動就會關閉曾使用過的所有資源
Vicen
高階會員


發表:13
回覆:145
積分:151
註冊:2005-03-14

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-11-20 11:18:57 IP:221.226.xxx.xxx 未訂閱
huangeider兄的方法用遍历窗体控件方式关闭,随可以达到关闭目的,但实际还是去一个一个执行table.close方法,这种方法使用多会让初学者不能养成良好的编程习惯,让初学者养成只管开不去关的毛病,在以后编程中对于内存/文件等使用会埋下弊端,因为他们意识上关闭工作都不需要手动去做的. 这仅是在下愚见,并非与huangeider兄争辩,待到程序熟练,充分理解程序运作流程时再使用也不妨~ 至于digitraveler 说法,在下不敢苟同,APPLICTION并不能释放所有资源,而且这种编程思想是万万不可取的,望初学者不可采纳. 發表人 - vicen 於 2005/11/20 11:23:49
系統時間:2024-07-02 7:37:37
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!