首頁(yè) 考試吧論壇 Exam8視線 考試商城 網(wǎng)絡(luò)課程 模擬考試 考友錄 實(shí)用文檔 求職招聘 論文下載
2011中考 | 2011高考 | 2012考研 | 考研培訓(xùn) | 在職研 | 自學(xué)考試 | 成人高考 | 法律碩士 | MBA考試
MPA考試 | 中科院
四六級(jí) | 職稱英語(yǔ) | 商務(wù)英語(yǔ) | 公共英語(yǔ) | 托福 | 雅思 | 專四專八 | 口譯筆譯 | 博思 | GRE GMAT
新概念英語(yǔ) | 成人英語(yǔ)三級(jí) | 申碩英語(yǔ) | 攻碩英語(yǔ) | 職稱日語(yǔ) | 日語(yǔ)學(xué)習(xí) | 法語(yǔ) | 德語(yǔ) | 韓語(yǔ)
計(jì)算機(jī)等級(jí)考試 | 軟件水平考試 | 職稱計(jì)算機(jī) | 微軟認(rèn)證 | 思科認(rèn)證 | Oracle認(rèn)證 | Linux認(rèn)證
華為認(rèn)證 | Java認(rèn)證
公務(wù)員 | 報(bào)關(guān)員 | 銀行從業(yè)資格 | 證券從業(yè)資格 | 期貨從業(yè)資格 | 司法考試 | 法律顧問(wèn) | 導(dǎo)游資格
報(bào)檢員 | 教師資格 | 社會(huì)工作者 | 外銷員 | 國(guó)際商務(wù)師 | 跟單員 | 單證員 | 物流師 | 價(jià)格鑒證師
人力資源 | 管理咨詢師考試 | 秘書資格 | 心理咨詢師考試 | 出版專業(yè)資格 | 廣告師職業(yè)水平
駕駛員 | 網(wǎng)絡(luò)編輯
衛(wèi)生資格 | 執(zhí)業(yè)醫(yī)師 | 執(zhí)業(yè)藥師 | 執(zhí)業(yè)護(hù)士
會(huì)計(jì)從業(yè)資格考試會(huì)計(jì)證) | 經(jīng)濟(jì)師 | 會(huì)計(jì)職稱 | 注冊(cè)會(huì)計(jì)師 | 審計(jì)師 | 注冊(cè)稅務(wù)師
注冊(cè)資產(chǎn)評(píng)估師 | 高級(jí)會(huì)計(jì)師 | ACCA | 統(tǒng)計(jì)師 | 精算師 | 理財(cái)規(guī)劃師 | 國(guó)際內(nèi)審師
一級(jí)建造師 | 二級(jí)建造師 | 造價(jià)工程師 | 造價(jià)員 | 咨詢工程師 | 監(jiān)理工程師 | 安全工程師
質(zhì)量工程師 | 物業(yè)管理師 | 招標(biāo)師 | 結(jié)構(gòu)工程師 | 建筑師 | 房地產(chǎn)估價(jià)師 | 土地估價(jià)師 | 巖土師
設(shè)備監(jiān)理師 | 房地產(chǎn)經(jīng)紀(jì)人 | 投資項(xiàng)目管理師 | 土地登記代理人 | 環(huán)境影響評(píng)價(jià)師 | 環(huán)保工程師
城市規(guī)劃師 | 公路監(jiān)理師 | 公路造價(jià)師 | 安全評(píng)價(jià)師 | 電氣工程師 | 注冊(cè)測(cè)繪師 | 注冊(cè)計(jì)量師
繽紛校園 | 實(shí)用文檔 | 英語(yǔ)學(xué)習(xí) | 作文大全 | 求職招聘 | 論文下載 | 訪談 | 游戲

用DDE實(shí)現(xiàn)窗體防止運(yùn)行多個(gè)實(shí)例并傳遞命令

本文為“用DDE實(shí)現(xiàn)窗體防止運(yùn)行多個(gè)實(shí)例并傳遞命令”,以供廣大學(xué)員參考使用。更多關(guān)于計(jì)算機(jī)等級(jí)考試資料,請(qǐng)?jiān)L問(wèn)考試吧計(jì)算機(jī)等級(jí)考試頻道。

  上網(wǎng)的朋友一定都用過(guò)網(wǎng)絡(luò)螞蟻(Net Ants)的吧?不知你在使用過(guò)程中有沒(méi)有注意過(guò),那就是如果你想調(diào)動(dòng)兩個(gè)“螞蟻”為您效力是不可能的——它總會(huì)把新運(yùn)行的關(guān)閉。這點(diǎn)在VB中很容易實(shí)現(xiàn):

  Private Sub Form_Load()

  If App.PrevInstance Then

  MsgBox "你已經(jīng)運(yùn)行這個(gè)應(yīng)用程序了"

  End’ 退出新運(yùn)行的程序

  End If

  End Sub

  這樣如果你運(yùn)行這個(gè)程序后在運(yùn)行它,它會(huì)彈出一個(gè)消息框并拒絕再次運(yùn)行。這非常容易。

  而“螞蟻”程序的妙處就在于:在重復(fù)運(yùn)行“螞蟻”時(shí)它不僅拒絕運(yùn)行,而且能把已經(jīng)運(yùn)行的“螞蟻”激活,這樣用上面的程序就無(wú)能為力了。但事實(shí)上實(shí)現(xiàn)拒絕運(yùn)行并激活已運(yùn)行的程序有多種方法:

  1、用FindWindow函數(shù)得到已經(jīng)運(yùn)行窗體的句柄(HWND),然后用SetActiveWindow等API函數(shù)將其激活。其缺點(diǎn)也很明顯,那就是沒(méi)法傳遞參數(shù)。

  2、用FindWindow函數(shù)得到已運(yùn)行窗體的句柄后用SendMessage的方法給窗體傳送一個(gè)自定義消息(附帶參數(shù)),然后在窗體中攔截并進(jìn)行處理,但這樣做要修改窗體的標(biāo)準(zhǔn)消息處理程序,用在VC,BC或DELPHI編寫的程序中還行,但在VB中工作量太大,并且容易發(fā)生“一般保護(hù)行錯(cuò)誤”使VB崩潰,不太可取(當(dāng)然,如果你有足夠的信心和不怕崩潰的精神,也可以試一下 ^_^ )。

  3、使用DDE技術(shù)。

  所謂DDE技術(shù),就是動(dòng)態(tài)數(shù)據(jù)交換技術(shù)。也許你很奇怪,這與本文所討論的內(nèi)容有什么相干的?且聽(tīng)我慢慢講來(lái)。

  為了實(shí)現(xiàn)拒絕運(yùn)行并把已經(jīng)運(yùn)行的程序激活并實(shí)現(xiàn)各種功能,我們可以先用本文開(kāi)頭提到的方法,檢測(cè)一下程序有沒(méi)有被運(yùn)行過(guò),如果沒(méi)有,就正常運(yùn)行,如果已經(jīng)被運(yùn)行過(guò),就打通與它的DDE通道,傳給它一個(gè)(或一些)數(shù)據(jù),然后由已經(jīng)運(yùn)行的程序?qū)?shù)據(jù)進(jìn)行處理,再去實(shí)現(xiàn)各種“意想不到”的功能,這時(shí)也許就有人對(duì)這你的程序喊:“酷、酷……” ^_^

  好了,耳聽(tīng)為虛,眼見(jiàn)為實(shí),下面讓我們動(dòng)點(diǎn)真格的。

  打開(kāi)VB,新建一個(gè)工程,選擇菜單中的“工程->工程1 屬性”,把工程名稱改為“P1”(我愛(ài)偷懶,能短則短 ^_^ ),把已有的一個(gè)窗體的“LinkTopic”屬性改為“FormDDE”,把“LinkMode”屬性改為“1 - Source”,添加一個(gè)PictureBox控件作為DDE執(zhí)行控件,命名為picDDE。然后添加一個(gè)

  TextBox控件,命名為“txtInfo”,并把“MultiLine”屬性設(shè)置為“True”,以便顯示多行文本,作為消息顯示控件。

  最后在窗體代碼區(qū)輸入以下代碼:

  Const COMMANDLINE = "CommandLine=" ’ 還是為了省事,定義一個(gè)常量

  Private Sub Form_LinkExecute(CmdStr As String, Cancel As Integer)

  Static lngCount As Long

  Dim Info As String

  Info = txtInfo.Text ’保留原有信息

  Select Case CmdStr’ CmdStr 是DDE程序傳送過(guò)來(lái)的參數(shù)

  Case "Max"

  Me.WindowState = 2

  Info = Info + vbNewLine + "窗體已被最大化"

  Case "ShowTime"

  Info = Info + vbNewLine + "最后一次運(yùn)行這個(gè)程序的時(shí)間是:" + Str(Now)

  Case "Count"

  lngCount = lngCount + 1

  Info = Info + vbNewLine + "你已經(jīng)第" + Str(lngCount) + "次重復(fù)調(diào)用這個(gè)程序。" _

  + vbNewLine + "但怕您不多給工資,所以只運(yùn)行了一個(gè) ^_^"

  End Select

  If Left(CmdStr, Len(COMMANDLINE)) = COMMANDLINE Then

  Info = Info + vbNewLine + "新程序曾以命令行形式運(yùn)行" + vbNewLine + "命令行為:" _

  + vbNewLine + Right(CmdStr, Len(CmdStr) - Len(COMMANDLINE))

  End If

  txtInfo.Text = Info ’ 把信息顯示出來(lái)

  Cancel = False

  End Sub

  Private Sub LinkAndSendMessage(ByVal Msg As String)

  Dim t As Long

  picDDE.LinkMode = 0’--

  picDDE.LinkTopic = "P1|FormDDE"’ |______連接DDE程序并發(fā)送數(shù)據(jù)/參數(shù)

  picDDE.LinkMode = 2’ |“|”為管道符,是“退格鍵”旁邊的豎線,

  picDDE.LinkExecute Msg’-- 不是字母或數(shù)字!

  t = picDDE.LinkTimeout ’--

  picDDE.LinkTimeout = 1 ’ |______終止DDE通道。當(dāng)然,也可以用別的方法

  picDDE.LinkMode = 0 ’ |這里用的是超時(shí)強(qiáng)制終止的方法

  picDDE.LinkTimeout = t ’--

  End Sub

  Private Sub Form_Load()

  If App.PrevInstance Then ’ 程序是否已經(jīng)運(yùn)行

  Me.LinkTopic = "" ’ 這兩行用于清除新運(yùn)行的程序的DDE服務(wù)器屬性,

  Me.LinkMode = 0’ 否則在連接DDE程序時(shí)會(huì)出亂子的

  LinkAndSendMessage "Max" ’--

  LinkAndSendMessage "Count" ’ |-----連接DDE接受程序并傳送數(shù)據(jù)/參數(shù)

  LinkAndSendMessage "ShowTime" ’--

  If Command <> "" Then ’ 如果有命令行參數(shù),就傳遞過(guò)去

  LinkAndSendMessage COMMANDLINE + Command

  End If

  End ’ 結(jié)束新程序的運(yùn)行

  End If

  End Sub

  測(cè)試一下:

  把工程“P1”編譯成EXE文件(設(shè)名稱為 P1.EXE )

  1、打開(kāi)“我的電腦”,找到 P1.EXE 并執(zhí)行。可以看到程序正常運(yùn)行了。

  2、再運(yùn)行一次,這次新程序沒(méi)有運(yùn)行成功,而原來(lái)運(yùn)行的程序卻被最大化了,而且文本框中有以下字符:

  窗體已被最大化

  你已經(jīng)第 1次重復(fù)調(diào)用這個(gè)程序。

  但怕您不多給工資,所以只運(yùn)行了一個(gè) ^_^

  最后一次運(yùn)行這個(gè)程序的時(shí)間是:00-2-6 7:11:01

  3、打開(kāi) MS-DOS方式 ,用命令行方式再次運(yùn)行程序,如 “P1 How Are You?”

  這時(shí)原來(lái)運(yùn)行的程序文本框中又多了幾行字:

  窗體已被最大化

  你已經(jīng)第 2次重復(fù)調(diào)用這個(gè)程序。

  但怕您不多給工資,所以只運(yùn)行了一個(gè) ^_^

  最后一次運(yùn)行這個(gè)程序的時(shí)間是:00-2-6 7:14:32

  新程序曾以命令行形式運(yùn)行

  命令行為:

  How Are You?

  OK,運(yùn)行完全正確,然后你就可以把它應(yīng)用的你的程序中了。

  當(dāng)然,這只是一些個(gè)人心得,如有疏漏之出,還請(qǐng)各位大蝦指正。

  相關(guān)推薦:2010年上半年全國(guó)計(jì)算機(jī)等考報(bào)名時(shí)間匯總
       2010年全國(guó)計(jì)算機(jī)等級(jí)二級(jí)VB考試題型與解題技巧
       免費(fèi)版:2010年計(jì)算機(jī)等級(jí)考試二級(jí)VB模擬試題11套
文章搜索
版權(quán)聲明:如果計(jì)算機(jī)等級(jí)考試網(wǎng)所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系800@exam8.com,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本計(jì)算機(jī)等級(jí)考試網(wǎng)內(nèi)容,請(qǐng)注明出處。