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

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| 亚洲第一中文字幕| 揄拍成人国产精品视频| 亚洲电影免费在线 | 一区在线免费| 亚洲国产成人久久| 亚洲美女av网站| 亚洲五月婷婷| 久久精品国产99国产精品| 久久久久久久波多野高潮日日| 老巨人导航500精品| 最新69国产成人精品视频免费| 亚洲二区视频| 一本色道婷婷久久欧美| 午夜在线a亚洲v天堂网2018| 久久亚洲电影| 久久精品国产清高在天天线| 国产精品尤物| 国内精品久久国产| 在线精品福利| 亚洲免费视频成人| 欧美+日本+国产+在线a∨观看| 亚洲精品亚洲人成人网| 欧美一级成年大片在线观看| 欧美a级片一区| 国产精品欧美日韩一区二区| 国产精品亚洲网站| 欧美一区二视频在线免费观看| 免费日韩一区二区| 欧美激情精品久久久久久大尺度 | 国产综合激情| 欧美一区二区精品| 欧美一区二区三区在线视频 | 亚洲电影在线看| 国产精品伦子伦免费视频| 欧美三级韩国三级日本三斤| 久久久久成人精品免费播放动漫| 欧美成年人网站| 欧美日韩亚洲高清一区二区| 国产精品成人久久久久| 国产视频一区在线观看一区免费| 亚洲精品久久久久久久久久久久| 亚洲综合日本| 91久久夜色精品国产九色| 亚洲性视频网站| 欧美激情视频免费观看| 国产精品午夜av在线| 欧美顶级少妇做爰| 久久精品五月婷婷| 国产精品v亚洲精品v日韩精品 | 国内一区二区三区在线视频| 久久精品论坛| 久久久精品国产免费观看同学 | 亚洲美女91| 欧美成人四级电影| 男女激情视频一区| 欧美色图麻豆| 午夜精彩国产免费不卡不顿大片| 亚洲精品国产精品久久清纯直播| 欧美伦理一区二区| 欧美成人午夜视频| 亚洲精品欧美专区| 蜜桃久久精品一区二区| 宅男在线国产精品| 亚洲日韩欧美一区二区在线| 香蕉久久夜色| 亚洲一级二级在线| 亚洲淫片在线视频| 欧美日韩国产欧| 性欧美xxxx视频在线观看| 两个人的视频www国产精品| 99这里只有精品| 国产偷久久久精品专区| 亚洲国产综合91精品麻豆| 日韩网站在线看片你懂的| 亚洲美女精品成人在线视频| 亚洲一区二区三区在线视频| 亚洲视频一区二区在线观看| 久久国产88| 麻豆精品视频在线观看| 国产在线精品一区二区夜色| 亚洲主播在线| 亚洲国产精品成人综合色在线婷婷| 在线观看日韩专区| 在线播放日韩专区| 亚洲欧美一区二区激情| 国产女人精品视频| 国产精品日韩一区二区三区| 香蕉亚洲视频| 欧美一区=区| 在线观看亚洲视频啊啊啊啊| 欧美激情免费观看| 欧美特黄一区| 久久免费视频这里只有精品| 欧美va天堂在线| 亚洲夜间福利| 久久精品成人一区二区三区蜜臀| 在线观看久久av| 亚洲精品国久久99热| 国产精品美女999| 久久一本综合频道| 欧美日韩国产首页在线观看| 久久国产主播精品| 欧美福利在线| 久久激情五月激情| 欧美大片在线观看一区| 亚洲欧美韩国| 美玉足脚交一区二区三区图片| 在线视频一区观看| 久久三级视频| 午夜精品久久| 久久综合国产精品| 午夜久久久久久久久久一区二区| 久久久99国产精品免费| 亚洲午夜视频在线| 久久影院午夜论| 亚洲午夜电影网| 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲女同精品视频| 快she精品国产999| 欧美一区激情视频在线观看| 欧美—级a级欧美特级ar全黄| 久久国产成人| 国产精品日韩欧美一区二区三区| 亚洲国产欧美不卡在线观看| 伊人久久综合97精品| 亚洲欧美另类在线| 亚洲一二三区视频在线观看| 欧美激情导航| 亚洲欧美日韩中文播放| 一区二区三区高清视频在线观看| 伊人精品视频| 欧美影院精品一区| 亚洲欧美激情精品一区二区| 欧美日韩精品一区二区在线播放 | 欧美黑人一区二区三区| 蜜臀av性久久久久蜜臀aⅴ| 国产欧美日本在线| 亚洲欧美国产精品专区久久| 亚洲欧美卡通另类91av | 日韩一区二区精品视频| 免费成人黄色av| 亚洲国产精品传媒在线观看 | 久久九九免费| 国产一区二区无遮挡| 香蕉免费一区二区三区在线观看 | 欧美激情一二区| 亚洲第一在线视频| 亚洲欧洲日韩综合二区| 久久综合狠狠综合久久激情| 久久综合色一综合色88| 影音先锋亚洲电影| 久久免费视频观看| 久久精品论坛| 亚洲高清一区二区三区| 欧美资源在线| 久久久久久久欧美精品| 亚洲黄色成人网| 模特精品在线| 亚洲精品国产系列| 日韩一区二区高清| 国产精品久久久久久影视| 一区二区精品| 亚洲伊人网站| 国产裸体写真av一区二区| 美女精品在线观看| 黄色欧美日韩| 久久综合九色九九| 日韩午夜在线播放| 国产精品videossex久久发布| 夜夜嗨一区二区| 亚洲欧美综合v| 国产日韩欧美亚洲一区| 欧美国产一区在线| 亚洲伦伦在线| 午夜在线a亚洲v天堂网2018| 国产欧美一区二区三区另类精品| 亚洲一区黄色| 久久久久综合一区二区三区| 在线观看视频亚洲| 欧美激情在线狂野欧美精品| 欧美一区二区视频网站| 亚洲日本免费电影| 欧美精品一区二区在线播放| 亚洲美女精品久久| 午夜国产精品视频| 亚洲精品久久久一区二区三区| 欧美精品亚洲二区| 亚洲一区二区三区国产| 久久人人爽人人| 性欧美大战久久久久久久免费观看 | 亚洲欧洲一区二区三区在线观看| 亚洲一区不卡| 亚洲国产日韩精品| 欧美视频在线观看一区二区| 欧美一乱一性一交一视频| 亚洲欧洲精品一区二区| 亚洲欧美三级伦理| 亚洲韩国日本中文字幕|