青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

cc

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  38 隨筆 :: 14 文章 :: 21 評論 :: 0 Trackbacks

Control.Invoke 方法 (Delegate):擁有此控件的基礎(chǔ)窗口句柄的線程上執(zhí)行指定的委托。

Control.BeginInvoke 方法 (Delegate) :在創(chuàng)建控件的基礎(chǔ)句柄所在線程上異步執(zhí)行指定委托。

(一)Control的Invoke和BeginInvoke
我們要基于以下認(rèn)識:
(1)Control的Invoke和BeginInvoke與Delegate的Invoke和BeginInvoke是不同的。
(2)Control的Invoke和BeginInvoke的參數(shù)為delegate,委托的方法是在Control的線程上執(zhí)行的,也就是我們平時所說的UI線程。

我們以代碼(一)來看(Control的Invoke)
private delegate void InvokeDelegate();
private void InvokeMethod(){
   //C代碼段
}
private void butInvoke_Click(object sender, EventArgs e) {
   //A代碼段.......
   this.Invoke(new InvokeDelegate(InvokeMethod));
   //B代碼段......
}
你覺得代碼的執(zhí)行順序是什么呢?記好Control的Invoke和BeginInvoke都執(zhí)行在主線程即UI線程上
A------>C---------------->B
解釋:(1)A在UI線程上執(zhí)行完后,開始Invoke,Invoke是同步
(2)代碼段B并不執(zhí)行,而是立即在UI線程上執(zhí)行InvokeMethod方法,即代碼段C。
(3)InvokeMethod方法執(zhí)行完后,代碼段C才在UI線程上繼續(xù)執(zhí)行。

看看代碼(二),Control的BeginInvoke
private delegate void BeginInvokeDelegate();
private void BeginInvokeMethod(){
   //C代碼段
}
private void butBeginInvoke_Click(object sender, EventArgs e) {
   //A代碼段.......
   this.BeginInvoke(new BeginInvokeDelegate(BeginInvokeMethod));
   //B代碼段......
}

你覺得代碼的執(zhí)行順序是什么呢?記好Control的Invoke和BeginInvoke都執(zhí)行在主線程即UI線程上
A----------->B--------------->C慎重,這個只做參考。。。。。,我也不肯定執(zhí)行順序,如果有哪位達人知道的話請告知。
解釋::(1)A在UI線程上執(zhí)行完后,開始BeginInvoke,BeginInvoke是異步
(2)InvokeMethod方法,即代碼段C不會執(zhí)行,而是立即在UI線程上執(zhí)行代碼段B。
(3)代碼段B執(zhí)行完后(就是說butBeginInvoke_Click方法執(zhí)行完后),InvokeMethod方法,即代碼段C才在UI線程上繼續(xù)執(zhí)行。

由此,我們知道:
Control的Invoke和BeginInvoke的委托方法是在主線程,即UI線程上執(zhí)行的。也就是說如果你的委托方法用來取花費時間長的數(shù)據(jù),然后更新界面什么的,千萬別在UI線程上調(diào)用Control.Invoke和Control.BeginInvoke,因為這些是依然阻塞UI線程的,造成界面的假死。

那么,這個異步到底是什么意思呢?

異步是指相對于調(diào)用BeginInvoke的線程異步,而不是相對于UI線程異步,你在UI線程上調(diào)用BeginInvoke ,當(dāng)然不行了。----摘自"Invoke和BeginInvoke的真正涵義"一文中的評論。
BeginInvoke的原理是將調(diào)用的方法Marshal成消息,然后調(diào)用Win32 API中的RegisterWindowMessage()向UI窗口發(fā)送消息。----摘自"Invoke和BeginInvoke的真正涵義"一文中的評論。

(二)我們用Thread來調(diào)用BeginInvoke和Invoke
      我們開一個線程,讓線程執(zhí)行一些耗費時間的操作,然后再用Control.Invoke和Control.BeginInvoke回到用戶UI線程,執(zhí)行界面更新。

代碼(三)  Thread調(diào)用Control的Invoke
private Thread invokeThread;
private delegate void invokeDelegate();
private void StartMethod(){
   //C代碼段......
   Control.Invoke(new invokeDelegate(invokeMethod));
  //D代碼段......
}
private void invokeMethod(){
  //E代碼段
}
private void butInvoke_Click(object sender, EventArgs e) {
   //A代碼段.......
   invokeThread = new Thread(new ThreadStart(StartMethod));
   invokeThread.Start();
   //B代碼段......
}

你覺得代碼的執(zhí)行順序是什么呢?記好Control的Invoke和BeginInvoke都執(zhí)行在主線程即UI線程上
A------>(Start一開始B和StartMethod的C就同時執(zhí)行)---->(C執(zhí)行完了,不管B有沒有執(zhí)行完,invokeThread把消息封送(invoke)給UI線程,然后自己等待)---->UI線程處理完butInvoke_Click消息后,處理invokeThread封送過來的消息,執(zhí)行invokeMethod方法,即代碼段E,處理往后UI線程切換到invokeThread線程。
這個Control.Invoke是相對于invokeThread線程同步的,阻止了其運行。

解釋:
1。UI執(zhí)行A
2。UI開線程InvokeThread,B和C同時執(zhí)行,B執(zhí)行在線程UI上,C執(zhí)行在線程invokeThread上。
3。invokeThread封送消息給UI,然后自己等待,UI處理完消息后,處理invokeThread封送的消息,即代碼段E
4。UI執(zhí)行完E后,轉(zhuǎn)到線程invokeThread上,invokeThread線程執(zhí)行代碼段D

代碼(四)  Thread調(diào)用Control的BeginInvoke
private Thread beginInvokeThread;
private delegate void beginInvokeDelegate();
private void StartMethod(){
   //C代碼段......
   Control.BeginInvoke(new beginInvokeDelegate(beginInvokeMethod));
  //D代碼段......
}
private void beginInvokeMethod(){
  //E代碼段
}
private void butBeginInvoke_Click(object sender, EventArgs e) {
   //A代碼段.......
   beginInvokeThread = new Thread(new ThreadStart(StartMethod));
   beginInvokeThread .Start();
   //B代碼段......
}
你覺得代碼的執(zhí)行順序是什么呢?記好Control的Invoke和BeginInvoke都執(zhí)行在主線程即UI線程上
A在UI線程上執(zhí)行----->beginInvokeThread線程開始執(zhí)行,UI繼續(xù)執(zhí)行代碼段B,并發(fā)地invokeThread執(zhí)行代碼段C-------------->不管UI有沒有執(zhí)行完代碼段B,這時beginInvokeThread線程把消息封送給UI,單自己并不等待,繼續(xù)向下執(zhí)行-------->UI處理完butBeginInvoke_Click消息后,處理beginInvokeThread線程封送過來的消息。


解釋:
1。UI執(zhí)行A
2。UI開線程beginInvokeThread,B和C同時執(zhí)行,B執(zhí)行在線程UI上,C執(zhí)行在線程beginInvokeThread上。
3。beginInvokeThread封送消息給UI,然后自己繼續(xù)執(zhí)行代碼D,UI處理完消息后,處理invokeThread封送的消息,即代碼段E
有點疑問:如果UI先執(zhí)行完畢,是不是有可能過了段時間beginInvokeThread才把消息封送給UI,然后UI才繼續(xù)執(zhí)行封送的消息E。如圖淺綠的部分。


Control的BeginInvoke是相對于調(diào)用它的線程,即beginInvokeThread相對是異步的。
因此,我們可以想到。如果要異步取耗費長時間的數(shù)據(jù),比如從數(shù)據(jù)庫中讀大量數(shù)據(jù),我們應(yīng)該這么做。
(1)如果你想阻止調(diào)用線程,那么調(diào)用代碼(三),代碼段D刪掉,C改為耗費長時間的操作,因為這個操作是在另外一個線程中做的。代碼段E改為更新界面的方法。
(2)如果你不想阻止調(diào)用線程,那么調(diào)用代碼(四),代碼段D刪掉,C改為耗費長時間的操作,因為這個操作是在另外一個線程中做的。代碼段E改為更新界面的方法。

==============================以上是原帖=============================

       我認(rèn)為上面“代碼二”給出的運行結(jié)果是正確的。我來做個總結(jié):委托的同步和異步的區(qū)別,只有在多線程中才能體現(xiàn)的出來。以跨線程操作控件為例,采用異步時則向UI線程發(fā)送一個消息,然后該干嘛干嘛,這個消息什么時候會得到相應(yīng)是不一定的。如果采用同步執(zhí)行則向UI線程發(fā)送一個消息,然后一直等待,直到這個消息被相應(yīng)后才接著向下執(zhí)行。也就是說,在不跨線程的時候(在UI線程中操作控件)同步和異步是沒有區(qū)別的,當(dāng)然,不跨線程就可以直接操作控件了,沒必要利用委托。

posted on 2011-02-27 14:05 醒目西西 閱讀(1279) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久午夜羞羞影院免费观看| 欧美电影免费| 一区视频在线播放| 国产欧美日韩亚洲精品| 国产欧美日韩一区二区三区在线 | 欧美性色综合| 国产精品日韩精品欧美在线| 国产欧美亚洲视频| 在线观看欧美日韩国产| 亚洲精选一区二区| 亚洲伊人色欲综合网| 欧美在线首页| 另类春色校园亚洲| 亚洲精品中文字| 亚洲免费伊人电影在线观看av| 久久精品视频免费播放| 欧美巨乳在线| 韩国久久久久| 亚洲一区二区黄| 欧美成人精品激情在线观看| 日韩亚洲精品视频| 久久国产精品久久精品国产| 欧美精品一区在线播放| 亚洲最新在线| 久久午夜激情| 国产精品少妇自拍| 91久久综合亚洲鲁鲁五月天| 午夜精品一区二区三区在线| 欧美韩日一区二区| 午夜精品久久久久久久久久久| 久久一区二区三区超碰国产精品| 欧美午夜欧美| 亚洲伦理久久| 男人天堂欧美日韩| 午夜精品亚洲一区二区三区嫩草| 欧美多人爱爱视频网站| 黑人操亚洲美女惩罚| 香蕉国产精品偷在线观看不卡 | 女主播福利一区| 亚洲深夜av| 欧美日韩国语| 亚洲日本欧美在线| 免费亚洲一区二区| 欧美专区18| 国产美女精品视频免费观看| 在线综合亚洲欧美在线视频| 欧美黄色影院| 久久女同互慰一区二区三区| 国产日本欧美视频| 亚洲影院一区| 一区二区三区三区在线| 欧美精品一区三区| 日韩视频一区二区在线观看 | 国产日韩精品视频一区| 亚洲性av在线| 一本久道久久综合婷婷鲸鱼| 欧美美女bb生活片| 99re热这里只有精品免费视频| 欧美a级一区| 久久免费偷拍视频| 亚洲国产欧美一区二区三区久久| 美女亚洲精品| 欧美v日韩v国产v| 亚洲伦理在线观看| 亚洲精品偷拍| 欧美亚洲成人免费| 午夜久久久久久| 欧美一区二区精品久久911| 国产精品亚洲综合色区韩国| 欧美亚洲网站| 久久国产精品99国产| 在线观看日韩专区| 亚洲国产成人精品视频| 欧美高潮视频| 亚洲一区二区高清| 欧美一区二区| 亚洲国产裸拍裸体视频在线观看乱了中文| 91久久午夜| 亚洲国产精品久久人人爱蜜臀| 老巨人导航500精品| 日韩亚洲精品电影| 一区二区免费在线观看| 国产欧美日韩亚洲一区二区三区| 久久精品成人| 免费的成人av| 亚洲欧美日韩专区| 久久久成人精品| 亚洲精品一区二区网址| 亚洲视频高清| 在线欧美日韩国产| 中日韩午夜理伦电影免费| 国产一区二区三区成人欧美日韩在线观看| 欧美gay视频| 国产精品国产自产拍高清av| 久久久久在线观看| 欧美日韩一区二区视频在线观看| 欧美永久精品| 欧美国产日韩在线| 久久久久国产免费免费| 欧美黄色免费网站| 久久久久久一区二区| 欧美日韩国产在线| 免费高清在线一区| 国产精品一区二区女厕厕| 欧美电影在线观看| 国产亚洲精品一区二555| 亚洲六月丁香色婷婷综合久久| 国产日韩欧美不卡在线| 亚洲国产精品久久91精品| 国产亚洲激情在线| 亚洲深夜激情| 9色精品在线| 噜噜噜久久亚洲精品国产品小说| 午夜精品久久久久久99热软件| 麻豆精品精品国产自在97香蕉| 午夜精品久久久| 欧美午夜精品理论片a级按摩| 欧美顶级大胆免费视频| 精品福利免费观看| 欧美一区二区三区免费大片| 亚洲欧美国产日韩天堂区| 欧美激情一区二区三区| 欧美国产日本在线| 亚洲国产精品小视频| 久久爱另类一区二区小说| 欧美一区二区三区的| 国产精品欧美一区二区三区奶水 | 欧美在线观看网址综合| 亚洲午夜小视频| 欧美精品在线看| 亚洲国产毛片完整版| 亚洲国产精品久久久久秋霞蜜臀| 欧美一区午夜精品| 久久夜色精品国产亚洲aⅴ | 精品成人一区二区| 亚洲自拍三区| 欧美一区二区三区在线免费观看| 欧美丝袜第一区| 欧美一区2区三区4区公司二百 | 欧美午夜不卡视频| 日韩亚洲欧美一区二区三区| 亚洲理论在线| 欧美日韩精品一区| 亚洲午夜电影在线观看| 亚洲欧美在线网| 国产精品免费网站在线观看| 亚洲桃花岛网站| 久久精品国产久精国产爱| 国产在线视频欧美| 久久永久免费| 亚洲激精日韩激精欧美精品| 一本综合久久| 国产精品毛片在线看| 羞羞答答国产精品www一本| 久久综合成人精品亚洲另类欧美| 亚洲成人在线观看视频| 欧美精品18+| 亚洲综合精品自拍| 久热精品在线视频| 日韩一级免费| 国产精品一二三| 久久久综合免费视频| 亚洲日本理论电影| 久久国产88| 亚洲精品视频在线观看免费| 国产精品久久福利| 久久久久一区二区三区四区| 亚洲精品乱码久久久久久日本蜜臀| 夜夜爽夜夜爽精品视频| 国产精品视频区| 麻豆免费精品视频| 亚洲视频一区二区免费在线观看| 欧美专区在线观看一区| 亚洲人被黑人高潮完整版| 国产精品国产| 免费短视频成人日韩| 亚洲欧美日韩成人| 亚洲国产影院| 久久国内精品自在自线400部| 亚洲激情在线播放| 国产精品一二一区| 欧美波霸影院| 久久成年人视频| 亚洲深夜福利| 91久久精品美女高潮| 久久天堂av综合合色| 99综合电影在线视频| 激情综合色丁香一区二区| 国产精品国产三级国产专区53 | 国内精品久久久久影院优| 欧美精品免费观看二区| 久久久精品tv| 亚洲一区亚洲| 日韩午夜免费视频| 亚洲二区精品| 免费在线观看成人av| 久久看片网站| 久久精品国产欧美激情| 午夜天堂精品久久久久| 亚洲一区二区视频在线|