真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

vb.net檢測進(jìn)程 vbs查看窗口是否存在

vb net 怎么樣判斷 Windows任務(wù)管理器進(jìn)程,比如excel.exe存在側(cè)button1

button1.visible=false

站在用戶的角度思考問題,與客戶深入溝通,找到滎經(jīng)網(wǎng)站設(shè)計與滎經(jīng)網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗,讓設(shè)計與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個性化、用戶體驗好的作品,建站類型包括:成都網(wǎng)站設(shè)計、做網(wǎng)站、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名注冊、虛擬主機(jī)、企業(yè)郵箱。業(yè)務(wù)覆蓋滎經(jīng)地區(qū)。

For Each i In Process.GetProcessesByName("excel")

button1.visible=true

next

VB.net在Windows7下檢測進(jìn)程是否存在

VB.net(VS2008)里面比C#還好弄,不需要自己加manifest,直接在項目屬性的“應(yīng)用程序”里面點擊“查看UAC設(shè)置”,在新打開的app.manifest里面把 requestedExecutionLevel level="asInvoker" uiAccess="false" / 替換成 requestedExecutionLevel level="requireAdministrator" uiAccess="false" / 再編譯就行了。

vb 如何快速檢測某進(jìn)程是否正在運(yùn)行?并且獲得這個進(jìn)程所在的路徑呢? 謝啦!

方法一:系統(tǒng)任務(wù)欄上鼠標(biāo)右鍵啟動任務(wù)管理器---進(jìn)程選項中可查到你要的!

方法二:鍵盤按Ctrl+Alt+Delete 直接啟動任務(wù)管理器

錯了 你說的是VB中 我看錯了呵呵 我查查再回答哈

Private Sub Form_Load()

If App.PrevInstance Then

End

End If

End Sub

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

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

Private Sub Form_Load()

If App.PrevInstance Then

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

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

End If

End Sub

這樣如果你運(yùn)行這個程序后在運(yùn)行它,它會彈出一個消息框并拒絕再次運(yùn)行。這非常容易。 而“螞蟻”程序的妙處就在于:在重復(fù)運(yùn)行“螞蟻”時它不僅拒絕運(yùn)行,而且能把已經(jīng)運(yùn)行的“螞蟻”激活,這樣用上面的程序就無能為力了。但事實上實現(xiàn)拒絕運(yùn)行并激活已運(yùn)行的

程序有多種方法:

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

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

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

所謂DDE技術(shù),就是動態(tài)數(shù)據(jù)交換技術(shù)。也許你很奇怪,這與本文所討論的內(nèi)容有什么相干的?

且聽我慢慢講來。

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

好了,耳聽為虛,眼見為實,下面讓我們動點真格的。

打開VB,新建一個工程,選擇菜單中的“工程-工程1 屬性”,把工程名稱改為“P1”(我愛偷懶,能短則短 ^_^ ),把已有的一個窗體的“LinkTopic”屬性改為“FormDDE”,把“LinkMode”屬性改為“1 - Source”,添加一個PictureBox控件作為DDE執(zhí)行控件,命名為picDDE。然后添加一個TextBox控件,命名為“txtInfo”,并把“MultiLine”屬性設(shè)置為“True”,以便顯示多行文本,作為消息顯示控件。

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

Const COMMANDLINE = "CommandLine=" ' 還是為了省事,定義一個常量

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程序傳送過來的參數(shù)

Case "Max"

Me.WindowState = 2

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

Case "ShowTime"

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

Case "Count"

lngCount = lngCount + 1

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

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

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 ' 把信息顯示出來

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 ' | 這里用的是超時強(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程序時會出亂子的

LinkAndSendMessage "Max" '--

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

LinkAndSendMessage "ShowTime" '--

If Command "" Then ' 如果有命令行參數(shù),就傳遞過去

LinkAndSendMessage COMMANDLINE + Command

End If

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

End If

End Sub

測試一下:

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

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

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

字符:

窗體已被最大化

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

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

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

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

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

窗體已被最大化

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

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

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

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

命令行為:

How Are You?

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

VB.NET怎樣判斷一個應(yīng)用程序是否在運(yùn)行

用process.GetProcesses()

或者process.GetProcessByid() 獲取進(jìn)程信息,


新聞標(biāo)題:vb.net檢測進(jìn)程 vbs查看窗口是否存在
文章地址:http://weahome.cn/article/dopijdh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部